home *** CD-ROM | disk | FTP | other *** search
MacBinary | 1994-03-25 | 52.8 KB | [TEXT/ROSA] |
open in:
MacOS 8.1
|
Win98
|
DOS
browse contents |
view JSON data
|
view as text
This file was processed as: MacBinary
(archive/macBinary).
Confidence | Program | Detection | Match Type | Support
|
---|
10%
| dexvert
| MacBinary (archive/macBinary)
| fallback
| Supported |
1%
| dexvert
| Text File (text/txt)
| fallback
| Supported |
100%
| file
| MacBinary II, inited, Fri Mar 25 00:53:43 1994, modified Fri Mar 25 00:53:43 1994, creator 'ROSA', type ASCII, 52890 bytes "compiler.lisp" , at 0xcf1a 852 bytes resource
| default (weak)
| |
99%
| file
| data
| default
| |
74%
| TrID
| Macintosh plain text (MacBinary)
| default
| |
25%
| TrID
| MacBinary 2
| default (weak)
| |
100%
| siegfried
| fmt/1762 MacBinary (II)
| default
| |
100%
| lsar
| MacBinary
| default
|
|
id metadata |
---|
key | value |
---|
macFileType | [TEXT] |
macFileCreator | [ROSA] |
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 0d 63 6f 6d 70 69 6c | 65 72 2e 6c 69 73 70 00 |..compil|er.lisp.|
|00000010| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 52 4f 53 | 41 01 00 00 00 00 00 00 |.TEXTROS|A.......|
|00000050| 00 00 00 00 00 ce 9a 00 | 00 03 54 a9 b8 2c e7 a9 |........|..T..,..|
|00000060| b8 2c e7 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |.,......|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 e4 30 00 00 |........|.....0..|
|00000080| 3b 3b 3b 0d 3b 3b 3b 09 | 09 43 6f 70 79 72 69 67 |;;;.;;;.|.Copyrig|
|00000090| 68 74 20 a9 20 31 39 39 | 34 20 52 6f 67 65 72 20 |ht . 199|4 Roger |
|000000a0| 43 6f 72 6d 61 6e 2e 20 | 20 41 6c 6c 20 72 69 67 |Corman. | All rig|
|000000b0| 68 74 73 20 72 65 73 65 | 72 76 65 64 2e 0d 3b 3b |hts rese|rved..;;|
|000000c0| 3b 0d 0d 3b 0d 3b 09 53 | 6f 75 72 63 65 20 63 6f |;..;.;.S|ource co|
|000000d0| 64 65 20 66 6f 72 20 63 | 6f 6d 70 69 6c 65 72 2e |de for c|ompiler.|
|000000e0| 0d 3b 09 54 68 69 73 20 | 69 73 20 69 6e 63 6c 75 |.;.This |is inclu|
|000000f0| 64 65 64 20 69 6e 20 74 | 68 65 20 22 43 4f 4d 50 |ded in t|he "COMP|
|00000100| 49 4c 45 52 22 20 70 61 | 63 6b 61 67 65 2e 0d 3b |ILER" pa|ckage..;|
|00000110| 0d 0d 28 65 76 61 6c 2d | 77 68 65 6e 20 28 3a 63 |..(eval-|when (:c|
|00000120| 6f 6d 70 69 6c 65 2d 74 | 6f 70 6c 65 76 65 6c 20 |ompile-t|oplevel |
|00000130| 3a 6c 6f 61 64 2d 74 6f | 70 6c 65 76 65 6c 20 3a |:load-to|plevel :|
|00000140| 65 78 65 63 75 74 65 29 | 0d 09 28 70 72 6f 76 69 |execute)|..(provi|
|00000150| 64 65 20 3a 63 6f 6d 70 | 69 6c 65 72 29 0d 09 28 |de :comp|iler)..(|
|00000160| 69 6e 2d 70 61 63 6b 61 | 67 65 20 3a 63 6f 6d 70 |in-packa|ge :comp|
|00000170| 69 6c 65 72 29 0d 09 28 | 72 65 71 75 69 72 65 20 |iler)..(|require |
|00000180| 3a 61 73 73 65 6d 62 6c | 65 72 29 0d 09 28 75 73 |:assembl|er)..(us|
|00000190| 65 2d 70 61 63 6b 61 67 | 65 20 3a 61 73 73 65 6d |e-packag|e :assem|
|000001a0| 62 6c 65 72 29 0d 09 28 | 65 78 70 6f 72 74 20 27 |bler)..(|export '|
|000001b0| 28 63 6f 6d 70 69 6c 65 | 72 3a 3a 63 6f 6d 70 69 |(compile|r::compi|
|000001c0| 6c 65 2d 74 6f 70 2d 6c | 65 76 65 6c 2d 66 6f 72 |le-top-l|evel-for|
|000001d0| 6d 29 29 29 0d 0d 28 65 | 76 61 6c 2d 77 68 65 6e |m)))..(e|val-when|
|000001e0| 20 28 3a 63 6f 6d 70 69 | 6c 65 2d 74 6f 70 6c 65 | (:compi|le-tople|
|000001f0| 76 65 6c 20 3a 6c 6f 61 | 64 2d 74 6f 70 6c 65 76 |vel :loa|d-toplev|
|00000200| 65 6c 20 3a 65 78 65 63 | 75 74 65 29 0d 09 28 64 |el :exec|ute)..(d|
|00000210| 65 66 75 6e 20 61 73 73 | 65 6d 62 6c 79 2d 73 74 |efun ass|embly-st|
|00000220| 61 72 74 20 28 73 74 72 | 65 61 6d 20 63 68 61 72 |art (str|eam char|
|00000230| 29 0d 09 09 28 63 6f 6e | 73 20 27 63 6f 6d 70 69 |)...(con|s 'compi|
|00000240| 6c 65 72 3a 3a 70 75 73 | 68 2d 61 73 73 65 6d 62 |ler::pus|h-assemb|
|00000250| 6c 79 2d 69 6e 73 74 72 | 75 63 74 69 6f 6e 73 20 |ly-instr|uctions |
|00000260| 28 72 65 61 64 2d 64 65 | 6c 69 6d 69 74 65 64 2d |(read-de|limited-|
|00000270| 6c 69 73 74 20 23 5c 5d | 20 73 74 72 65 61 6d 29 |list #\]| stream)|
|00000280| 29 29 0d 09 28 64 65 66 | 75 6e 20 61 73 73 65 6d |))..(def|un assem|
|00000290| 62 6c 79 2d 65 6e 64 20 | 28 73 74 72 65 61 6d 20 |bly-end |(stream |
|000002a0| 63 68 61 72 29 20 6e 69 | 6c 29 0d 09 28 73 65 74 |char) ni|l)..(set|
|000002b0| 2d 6d 61 63 72 6f 2d 63 | 68 61 72 61 63 74 65 72 |-macro-c|haracter|
|000002c0| 20 23 5c 5b 20 23 27 61 | 73 73 65 6d 62 6c 79 2d | #\[ #'a|ssembly-|
|000002d0| 73 74 61 72 74 29 0d 09 | 28 73 65 74 2d 6d 61 63 |start)..|(set-mac|
|000002e0| 72 6f 2d 63 68 61 72 61 | 63 74 65 72 20 23 5c 5d |ro-chara|cter #\]|
|000002f0| 20 23 27 61 73 73 65 6d | 62 6c 79 2d 65 6e 64 29 | #'assem|bly-end)|
|00000300| 29 0d 0d 3b 0d 3b 09 57 | 65 20 64 6f 20 61 6e 20 |)..;.;.W|e do an |
|00000310| 65 76 61 6c 2d 77 68 65 | 6e 20 6f 6e 20 74 68 65 |eval-whe|n on the|
|00000320| 20 65 6e 74 69 72 65 20 | 66 69 6c 65 20 73 6f 20 | entire |file so |
|00000330| 74 68 61 74 20 77 65 20 | 67 65 74 20 74 68 65 0d |that we |get the.|
|00000340| 3b 09 70 65 72 66 6f 72 | 6d 61 6e 63 65 20 62 65 |;.perfor|mance be|
|00000350| 6e 65 66 69 74 73 20 69 | 6d 6d 65 64 69 61 74 65 |nefits i|mmediate|
|00000360| 6c 79 0d 3b 0d 28 65 76 | 61 6c 2d 77 68 65 6e 20 |ly.;.(ev|al-when |
|00000370| 28 3a 63 6f 6d 70 69 6c | 65 2d 74 6f 70 6c 65 76 |(:compil|e-toplev|
|00000380| 65 6c 20 3a 6c 6f 61 64 | 2d 74 6f 70 6c 65 76 65 |el :load|-topleve|
|00000390| 6c 20 3a 65 78 65 63 75 | 74 65 29 0d 09 0d 28 64 |l :execu|te)...(d|
|000003a0| 65 66 76 61 72 20 2a 61 | 73 73 65 6d 62 6c 65 2d |efvar *a|ssemble-|
|000003b0| 63 6f 64 65 2a 20 74 29 | 0d 28 64 65 66 76 61 72 |code* t)|.(defvar|
|000003c0| 20 2a 61 73 6d 2a 20 6e | 69 6c 29 0d 28 64 65 66 | *asm* n|il).(def|
|000003d0| 76 61 72 20 2a 6c 65 78 | 2d 63 6f 75 6e 74 65 72 |var *lex|-counter|
|000003e0| 2a 20 30 29 0d 28 64 65 | 66 76 61 72 20 2a 72 65 |* 0).(de|fvar *re|
|000003f0| 66 65 72 65 6e 63 65 73 | 2a 20 6e 69 6c 29 0d 28 |ferences|* nil).(|
|00000400| 64 65 66 76 61 72 20 2a | 66 75 6e 63 74 69 6f 6e |defvar *|function|
|00000410| 2d 6e 61 6d 65 2a 20 6e | 69 6c 29 0d 28 64 65 66 |-name* n|il).(def|
|00000420| 76 61 72 20 2a 66 75 6e | 63 74 69 6f 6e 2d 65 6e |var *fun|ction-en|
|00000430| 74 72 79 2d 6c 61 62 65 | 6c 2a 20 6e 69 6c 29 0d |try-labe|l* nil).|
|00000440| 28 64 65 66 76 61 72 20 | 2a 63 6c 65 61 6e 75 70 |(defvar |*cleanup|
|00000450| 2d 66 6f 72 6d 73 2d 73 | 74 61 63 6b 2a 20 6e 69 |-forms-s|tack* ni|
|00000460| 6c 29 0d 28 64 65 66 76 | 61 72 20 2a 6c 61 6d 62 |l).(defv|ar *lamb|
|00000470| 64 61 2d 6c 69 73 74 2a | 20 6e 69 6c 29 0d 28 64 |da-list*| nil).(d|
|00000480| 65 66 76 61 72 20 2a 61 | 72 67 2d 63 6f 75 6e 74 |efvar *a|rg-count|
|00000490| 2a 20 30 29 0d 28 64 65 | 66 76 61 72 20 2a 6c 61 |* 0).(de|fvar *la|
|000004a0| 73 74 2d 63 61 6c 6c 2d | 77 61 73 2d 76 61 6c 75 |st-call-|was-valu|
|000004b0| 65 73 2a 20 6e 69 6c 29 | 0d 28 64 65 66 76 61 72 |es* nil)|.(defvar|
|000004c0| 20 2a 65 6e 76 69 72 6f | 6e 6d 65 6e 74 2a 20 6e | *enviro|nment* n|
|000004d0| 69 6c 29 0d 28 64 65 66 | 76 61 72 20 2a 65 6d 62 |il).(def|var *emb|
|000004e0| 65 64 64 65 64 2d 6c 61 | 6d 62 64 61 73 2a 20 6e |edded-la|mbdas* n|
|000004f0| 69 6c 29 0d 28 64 65 66 | 76 61 72 20 2a 6c 61 6d |il).(def|var *lam|
|00000500| 62 64 61 2d 73 70 65 63 | 69 61 6c 2d 76 61 72 73 |bda-spec|ial-vars|
|00000510| 2a 20 6e 69 6c 29 0d 28 | 64 65 66 76 61 72 20 2a |* nil).(|defvar *|
|00000520| 6c 61 6d 62 64 61 2d 64 | 65 63 6c 61 72 61 74 69 |lambda-d|eclarati|
|00000530| 6f 6e 73 2a 20 6e 69 6c | 29 0d 28 64 65 66 76 61 |ons* nil|).(defva|
|00000540| 72 20 2a 6c 61 6d 62 64 | 61 2d 73 70 65 63 69 61 |r *lambd|a-specia|
|00000550| 6c 2d 64 65 63 73 2a 20 | 6e 69 6c 29 0d 28 64 65 |l-decs* |nil).(de|
|00000560| 66 76 61 72 20 2a 63 6f | 6d 70 69 6c 65 2d 74 69 |fvar *co|mpile-ti|
|00000570| 6d 65 2d 74 6f 6f 2d 6d | 6f 64 65 2a 20 6e 69 6c |me-too-m|ode* nil|
|00000580| 29 20 0d 28 64 65 66 76 | 61 72 20 2a 63 6f 6d 70 |) .(defv|ar *comp|
|00000590| 69 6c 65 2d 70 72 69 6e | 74 2a 20 6e 69 6c 29 0d |ile-prin|t* nil).|
|000005a0| 28 64 65 66 76 61 72 20 | 2a 63 6f 6d 70 69 6c 65 |(defvar |*compile|
|000005b0| 2d 6f 75 74 70 75 74 2d | 66 69 6c 65 2a 20 6e 69 |-output-|file* ni|
|000005c0| 6c 29 0d 28 64 65 66 76 | 61 72 20 2a 73 79 6d 62 |l).(defv|ar *symb|
|000005d0| 6f 6c 2d 74 61 62 6c 65 | 2a 20 6e 69 6c 29 0d 28 |ol-table|* nil).(|
|000005e0| 64 65 66 76 61 72 20 2a | 6c 61 73 74 2d 63 61 6c |defvar *|last-cal|
|000005f0| 6c 2d 77 61 73 2d 74 61 | 69 6c 2d 72 65 63 75 72 |l-was-ta|il-recur|
|00000600| 73 69 6f 6e 2a 20 6e 69 | 6c 29 0d 0d 3b 3b 20 74 |sion* ni|l)..;; t|
|00000610| 6f 70 20 6c 65 76 65 6c | 20 66 6f 72 6d 73 20 77 |op level| forms w|
|00000620| 68 69 63 68 20 77 65 20 | 77 69 6c 6c 20 6f 75 74 |hich we |will out|
|00000630| 70 75 74 20 74 68 65 20 | 6e 61 6d 65 73 20 6f 66 |put the |names of|
|00000640| 20 77 68 69 6c 65 20 63 | 6f 6d 70 69 6c 69 6e 67 | while c|ompiling|
|00000650| 0d 3b 3b 20 69 66 20 2a | 63 6f 6d 70 69 6c 65 2d |.;; if *|compile-|
|00000660| 70 72 69 6e 74 2a 20 69 | 73 20 74 72 75 65 0d 28 |print* i|s true.(|
|00000670| 64 65 66 76 61 72 20 2a | 63 6f 6d 70 69 6c 65 72 |defvar *|compiler|
|00000680| 2d 70 72 69 6e 74 2d 66 | 6f 72 6d 73 2a 20 0d 09 |-print-f|orms* ..|
|00000690| 27 28 64 65 66 75 6e 20 | 64 65 66 6d 61 63 72 6f |'(defun |defmacro|
|000006a0| 20 64 65 66 73 74 72 75 | 63 74 20 64 65 66 63 6c | defstru|ct defcl|
|000006b0| 61 73 73 20 64 65 66 76 | 61 72 20 64 65 66 70 61 |ass defv|ar defpa|
|000006c0| 72 61 6d 65 74 65 72 20 | 64 65 66 63 6f 6e 73 74 |rameter |defconst|
|000006d0| 61 6e 74 29 29 0d 0d 28 | 64 65 66 75 6e 20 63 6f |ant))..(|defun co|
|000006e0| 6d 70 69 6c 65 2d 69 74 | 20 28 6e 61 6d 65 20 26 |mpile-it| (name &|
|000006f0| 6f 70 74 69 6f 6e 61 6c | 20 6c 61 6d 62 64 61 20 |optional| lambda |
|00000700| 26 61 75 78 20 28 6d 61 | 63 72 6f 20 6e 69 6c 29 |&aux (ma|cro nil)|
|00000710| 29 0d 09 28 75 6e 6c 65 | 73 73 20 28 74 79 70 65 |)..(unle|ss (type|
|00000720| 70 20 6e 61 6d 65 20 27 | 73 79 6d 62 6f 6c 29 20 |p name '|symbol) |
|00000730| 28 65 72 72 6f 72 20 22 | 46 75 6e 63 74 69 6f 6e |(error "|Function|
|00000740| 20 6e 61 6d 65 20 65 78 | 70 65 63 74 65 64 22 29 | name ex|pected")|
|00000750| 29 0d 09 28 75 6e 6c 65 | 73 73 20 6c 61 6d 62 64 |)..(unle|ss lambd|
|00000760| 61 20 28 73 65 74 66 20 | 6c 61 6d 62 64 61 20 28 |a (setf |lambda (|
|00000770| 66 75 6e 63 74 69 6f 6e | 2d 64 65 66 69 6e 69 74 |function|-definit|
|00000780| 69 6f 6e 20 28 73 79 6d | 62 6f 6c 2d 66 75 6e 63 |ion (sym|bol-func|
|00000790| 74 69 6f 6e 20 6e 61 6d | 65 29 29 29 29 0d 09 28 |tion nam|e))))..(|
|000007a0| 73 65 74 71 20 6d 61 63 | 72 6f 20 28 6d 61 63 72 |setq mac|ro (macr|
|000007b0| 6f 2d 66 75 6e 63 74 69 | 6f 6e 20 6e 61 6d 65 29 |o-functi|on name)|
|000007c0| 29 0d 09 28 75 6e 6c 65 | 73 73 20 28 65 71 20 28 |)..(unle|ss (eq (|
|000007d0| 63 61 72 20 6c 61 6d 62 | 64 61 29 20 27 6c 61 6d |car lamb|da) 'lam|
|000007e0| 62 64 61 29 20 28 65 72 | 72 6f 72 20 22 4e 6f 74 |bda) (er|ror "Not|
|000007f0| 20 61 20 6c 61 6d 62 64 | 61 20 65 78 70 72 65 73 | a lambd|a expres|
|00000800| 73 69 6f 6e 22 29 29 0d | 09 28 73 65 74 71 20 2a |sion")).|.(setq *|
|00000810| 61 73 73 65 6d 62 6c 65 | 2d 63 6f 64 65 2a 20 74 |assemble|-code* t|
|00000820| 29 0d 09 28 69 66 20 6d | 61 63 72 6f 0d 09 09 28 |)..(if m|acro...(|
|00000830| 73 65 74 66 20 28 6d 61 | 63 72 6f 2d 66 75 6e 63 |setf (ma|cro-func|
|00000840| 74 69 6f 6e 20 6e 61 6d | 65 29 20 28 63 6f 6d 70 |tion nam|e) (comp|
|00000850| 69 6c 65 2d 6c 61 6d 62 | 64 61 20 6c 61 6d 62 64 |ile-lamb|da lambd|
|00000860| 61 20 6e 61 6d 65 29 29 | 0d 09 09 28 73 65 74 66 |a name))|...(setf|
|00000870| 20 28 73 79 6d 62 6f 6c | 2d 66 75 6e 63 74 69 6f | (symbol|-functio|
|00000880| 6e 20 6e 61 6d 65 29 20 | 28 63 6f 6d 70 69 6c 65 |n name) |(compile|
|00000890| 2d 6c 61 6d 62 64 61 20 | 6c 61 6d 62 64 61 20 6e |-lambda |lambda n|
|000008a0| 61 6d 65 29 29 29 0d 09 | 6e 61 6d 65 29 0d 0d 28 |ame)))..|name)..(|
|000008b0| 64 65 66 75 6e 20 63 6f | 6d 70 69 6c 65 2d 77 69 |defun co|mpile-wi|
|000008c0| 74 68 6f 75 74 2d 61 73 | 73 65 6d 62 6c 69 6e 67 |thout-as|sembling|
|000008d0| 2d 69 74 20 28 6e 61 6d | 65 20 26 6f 70 74 69 6f |-it (nam|e &optio|
|000008e0| 6e 61 6c 20 6c 61 6d 62 | 64 61 20 26 61 75 78 20 |nal lamb|da &aux |
|000008f0| 28 6d 61 63 72 6f 20 6e | 69 6c 29 29 0d 09 28 75 |(macro n|il))..(u|
|00000900| 6e 6c 65 73 73 20 28 74 | 79 70 65 70 20 6e 61 6d |nless (t|ypep nam|
|00000910| 65 20 27 73 79 6d 62 6f | 6c 29 20 28 65 72 72 6f |e 'symbo|l) (erro|
|00000920| 72 20 22 46 75 6e 63 74 | 69 6f 6e 20 6e 61 6d 65 |r "Funct|ion name|
|00000930| 20 65 78 70 65 63 74 65 | 64 22 29 29 0d 09 28 75 | expecte|d"))..(u|
|00000940| 6e 6c 65 73 73 20 6c 61 | 6d 62 64 61 20 28 73 65 |nless la|mbda (se|
|00000950| 74 66 20 6c 61 6d 62 64 | 61 20 28 66 75 6e 63 74 |tf lambd|a (funct|
|00000960| 69 6f 6e 2d 64 65 66 69 | 6e 69 74 69 6f 6e 20 28 |ion-defi|nition (|
|00000970| 73 79 6d 62 6f 6c 2d 66 | 75 6e 63 74 69 6f 6e 20 |symbol-f|unction |
|00000980| 6e 61 6d 65 29 29 29 29 | 0d 09 28 73 65 74 71 20 |name))))|..(setq |
|00000990| 6d 61 63 72 6f 20 28 6d | 61 63 72 6f 2d 66 75 6e |macro (m|acro-fun|
|000009a0| 63 74 69 6f 6e 20 6e 61 | 6d 65 29 29 0d 09 28 75 |ction na|me))..(u|
|000009b0| 6e 6c 65 73 73 20 28 65 | 71 20 28 63 61 72 20 6c |nless (e|q (car l|
|000009c0| 61 6d 62 64 61 29 20 27 | 6c 61 6d 62 64 61 29 20 |ambda) '|lambda) |
|000009d0| 28 65 72 72 6f 72 20 22 | 4e 6f 74 20 61 20 6c 61 |(error "|Not a la|
|000009e0| 6d 62 64 61 20 65 78 70 | 72 65 73 73 69 6f 6e 22 |mbda exp|ression"|
|000009f0| 29 29 0d 09 28 73 65 74 | 71 20 2a 61 73 73 65 6d |))..(set|q *assem|
|00000a00| 62 6c 65 2d 63 6f 64 65 | 2a 20 6e 69 6c 29 0d 09 |ble-code|* nil)..|
|00000a10| 28 63 6f 6d 70 69 6c 65 | 2d 6c 61 6d 62 64 61 20 |(compile|-lambda |
|00000a20| 6c 61 6d 62 64 61 20 6e | 61 6d 65 29 29 0d 0d 28 |lambda n|ame))..(|
|00000a30| 64 65 66 75 6e 20 63 6f | 6d 70 69 6c 65 2d 74 68 |defun co|mpile-th|
|00000a40| 65 2d 66 69 6c 65 20 28 | 69 6e 70 75 74 2d 66 69 |e-file (|input-fi|
|00000a50| 6c 65 20 6f 75 74 70 75 | 74 2d 66 69 6c 65 20 70 |le outpu|t-file p|
|00000a60| 72 69 6e 74 29 0d 09 28 | 73 65 74 71 20 2a 61 73 |rint)..(|setq *as|
|00000a70| 73 65 6d 62 6c 65 2d 63 | 6f 64 65 2a 20 74 29 0d |semble-c|ode* t).|
|00000a80| 09 28 64 6f 2a 20 28 28 | 69 6e 66 69 6c 65 20 28 |.(do* ((|infile (|
|00000a90| 6f 70 65 6e 20 69 6e 70 | 75 74 2d 66 69 6c 65 29 |open inp|ut-file)|
|00000aa0| 29 20 0d 09 09 20 20 28 | 2a 63 6f 6d 70 69 6c 65 |) ... (|*compile|
|00000ab0| 2d 6f 75 74 70 75 74 2d | 66 69 6c 65 2a 20 28 70 |-output-|file* (p|
|00000ac0| 72 6f 67 6e 20 28 64 65 | 6c 65 74 65 2d 66 69 6c |rogn (de|lete-fil|
|00000ad0| 65 20 6f 75 74 70 75 74 | 2d 66 69 6c 65 29 20 28 |e output|-file) (|
|00000ae0| 6f 70 65 6e 20 6f 75 74 | 70 75 74 2d 66 69 6c 65 |open out|put-file|
|00000af0| 29 29 29 0d 09 09 20 20 | 28 2a 63 6f 6d 70 69 6c |)))... |(*compil|
|00000b00| 65 2d 70 72 69 6e 74 2a | 20 70 72 69 6e 74 29 0d |e-print*| print).|
|00000b10| 09 09 20 20 28 2a 70 61 | 63 6b 61 67 65 2a 20 2a |.. (*pa|ckage* *|
|00000b20| 70 61 63 6b 61 67 65 2a | 29 0d 09 09 20 20 28 2a |package*|)... (*|
|00000b30| 72 65 61 64 74 61 62 6c | 65 2a 20 2a 72 65 61 64 |readtabl|e* *read|
|00000b40| 74 61 62 6c 65 2a 29 0d | 09 09 20 20 28 2a 73 79 |table*).|.. (*sy|
|00000b50| 6d 62 6f 6c 2d 74 61 62 | 6c 65 2a 20 28 6d 61 6b |mbol-tab|le* (mak|
|00000b60| 65 2d 68 61 73 68 2d 74 | 61 62 6c 65 20 3a 73 69 |e-hash-t|able :si|
|00000b70| 7a 65 20 35 30 30 29 29 | 0d 09 09 20 20 28 69 6e |ze 500))|... (in|
|00000b80| 70 75 74 2d 65 78 70 72 | 65 73 73 69 6f 6e 20 28 |put-expr|ession (|
|00000b90| 72 65 61 64 20 69 6e 66 | 69 6c 65 29 20 28 72 65 |read inf|ile) (re|
|00000ba0| 61 64 20 69 6e 66 69 6c | 65 29 29 0d 09 09 20 20 |ad infil|e))... |
|00000bb0| 63 6f 64 65 0d 09 09 20 | 20 72 65 74 75 72 6e 2d |code... | return-|
|00000bc0| 76 61 6c 75 65 29 0d 09 | 09 20 28 28 65 71 20 69 |value)..|. ((eq i|
|00000bd0| 6e 70 75 74 2d 65 78 70 | 72 65 73 73 69 6f 6e 20 |nput-exp|ression |
|00000be0| 27 45 6f 66 29 20 0d 09 | 09 09 28 63 6c 6f 73 65 |'Eof) ..|..(close|
|00000bf0| 20 69 6e 66 69 6c 65 29 | 0d 09 09 09 28 73 65 74 | infile)|....(set|
|00000c00| 2d 66 69 6c 65 2d 74 79 | 70 65 20 2a 63 6f 6d 70 |-file-ty|pe *comp|
|00000c10| 69 6c 65 2d 6f 75 74 70 | 75 74 2d 66 69 6c 65 2a |ile-outp|ut-file*|
|00000c20| 20 22 46 41 53 4c 22 29 | 0d 09 09 09 28 63 6c 6f | "FASL")|....(clo|
|00000c30| 73 65 20 2a 63 6f 6d 70 | 69 6c 65 2d 6f 75 74 70 |se *comp|ile-outp|
|00000c40| 75 74 2d 66 69 6c 65 2a | 29 0d 09 09 09 6f 75 74 |ut-file*|)....out|
|00000c50| 70 75 74 2d 66 69 6c 65 | 29 0d 09 09 0d 09 09 28 |put-file|)......(|
|00000c60| 70 72 6f 63 65 73 73 2d | 74 6f 70 2d 6c 65 76 65 |process-|top-leve|
|00000c70| 6c 2d 66 6f 72 6d 73 20 | 28 6c 69 73 74 20 69 6e |l-forms |(list in|
|00000c80| 70 75 74 2d 65 78 70 72 | 65 73 73 69 6f 6e 29 29 |put-expr|ession))|
|00000c90| 29 29 0d 0d 3b 3b 0d 3b | 3b 09 54 68 65 20 66 6f |))..;;.;|;.The fo|
|00000ca0| 6c 6c 6f 77 69 6e 67 20 | 6c 6f 67 69 63 20 69 73 |llowing |logic is|
|00000cb0| 20 74 61 6b 65 6e 20 66 | 72 6f 6d 20 43 4c 54 4c | taken f|rom CLTL|
|00000cc0| 32 20 70 70 2e 39 30 2d | 39 31 0d 3b 3b 0d 28 64 |2 pp.90-|91.;;.(d|
|00000cd0| 65 66 75 6e 20 70 72 6f | 63 65 73 73 2d 74 6f 70 |efun pro|cess-top|
|00000ce0| 2d 6c 65 76 65 6c 2d 66 | 6f 72 6d 73 20 28 66 6f |-level-f|orms (fo|
|00000cf0| 72 6d 73 20 26 61 75 78 | 20 63 6f 64 65 20 72 65 |rms &aux| code re|
|00000d00| 74 75 72 6e 2d 76 61 6c | 75 65 20 70 72 69 6e 74 |turn-val|ue print|
|00000d10| 2d 66 6f 72 6d 29 0d 09 | 28 64 6f 6c 69 73 74 20 |-form)..|(dolist |
|00000d20| 28 66 20 66 6f 72 6d 73 | 29 0d 09 09 28 73 65 74 |(f forms|)...(set|
|00000d30| 71 20 70 72 69 6e 74 2d | 66 6f 72 6d 20 6e 69 6c |q print-|form nil|
|00000d40| 29 0d 09 09 28 69 66 20 | 28 6e 6f 74 20 28 63 6f |)...(if |(not (co|
|00000d50| 6e 73 70 20 66 29 29 20 | 28 67 6f 20 63 6f 6e 74 |nsp f)) |(go cont|
|00000d60| 69 6e 75 65 29 29 09 3b | 3b 20 6e 6f 20 6e 65 65 |inue)).;|; no nee|
|00000d70| 64 20 74 6f 20 70 72 6f | 63 65 73 73 20 6e 6f 6e |d to pro|cess non|
|00000d80| 2d 6c 69 73 74 20 66 6f | 72 6d 73 0d 09 09 09 0d |-list fo|rms.....|
|00000d90| 09 09 28 69 66 20 28 61 | 6e 64 20 2a 63 6f 6d 70 |..(if (a|nd *comp|
|00000da0| 69 6c 65 2d 70 72 69 6e | 74 2a 0d 09 09 09 09 28 |ile-prin|t*.....(|
|00000db0| 6d 65 6d 62 65 72 20 28 | 63 61 72 20 66 29 20 2a |member (|car f) *|
|00000dc0| 63 6f 6d 70 69 6c 65 72 | 2d 70 72 69 6e 74 2d 66 |compiler|-print-f|
|00000dd0| 6f 72 6d 73 2a 29 20 0d | 09 09 09 09 28 63 6f 6e |orms*) .|....(con|
|00000de0| 73 70 20 28 63 64 72 20 | 66 29 29 29 0d 09 09 09 |sp (cdr |f)))....|
|00000df0| 28 73 65 74 71 20 70 72 | 69 6e 74 2d 66 6f 72 6d |(setq pr|int-form|
|00000e00| 20 28 6c 69 73 74 20 28 | 63 61 72 20 66 29 20 28 | (list (|car f) (|
|00000e10| 63 61 64 72 20 66 29 20 | 22 2e 2e 2e 22 29 29 29 |cadr f) |"...")))|
|00000e20| 0d 0d 09 09 28 69 66 20 | 28 6d 61 63 72 6f 2d 66 |....(if |(macro-f|
|00000e30| 75 6e 63 74 69 6f 6e 20 | 28 63 61 72 20 66 29 29 |unction |(car f))|
|00000e40| 20 3b 3b 20 69 66 20 69 | 74 20 69 73 20 61 20 6d | ;; if i|t is a m|
|00000e50| 61 63 72 6f 20 65 78 70 | 61 6e 64 20 69 74 0d 09 |acro exp|and it..|
|00000e60| 09 09 28 70 72 6f 67 6e | 0d 09 09 09 09 28 73 65 |..(progn|.....(se|
|00000e70| 74 71 20 66 20 28 6d 61 | 63 72 6f 65 78 70 61 6e |tq f (ma|croexpan|
|00000e80| 64 20 66 29 29 0d 09 09 | 09 09 28 69 66 20 28 6e |d f))...|..(if (n|
|00000e90| 6f 74 20 28 63 6f 6e 73 | 70 20 66 29 29 20 28 67 |ot (cons|p f)) (g|
|00000ea0| 6f 20 63 6f 6e 74 69 6e | 75 65 29 29 29 29 20 3b |o contin|ue)))) ;|
|00000eb0| 3b 20 6e 6f 20 6e 65 65 | 64 20 74 6f 20 70 72 6f |; no nee|d to pro|
|00000ec0| 63 65 73 73 20 6e 6f 6e | 2d 6c 69 73 74 20 66 6f |cess non|-list fo|
|00000ed0| 72 6d 73 0d 0d 09 09 3b | 3b 20 77 61 74 63 68 20 |rms....;|; watch |
|00000ee0| 66 6f 72 20 73 6f 6d 65 | 20 73 70 65 63 69 61 6c |for some| special|
|00000ef0| 20 66 6f 72 6d 73 0d 09 | 09 28 69 66 20 28 73 70 | forms..|.(if (sp|
|00000f00| 65 63 69 61 6c 2d 66 6f | 72 6d 2d 70 20 28 63 61 |ecial-fo|rm-p (ca|
|00000f10| 72 20 66 29 29 0d 20 0d | 09 09 09 28 70 72 6f 67 |r f)). .|...(prog|
|00000f20| 6e 0d 09 09 09 09 3b 3b | 20 69 66 20 61 20 70 72 |n.....;;| if a pr|
|00000f30| 6f 67 6e 20 6f 72 20 6c | 6f 63 61 6c 6c 79 20 73 |ogn or l|ocally s|
|00000f40| 70 65 63 69 61 6c 20 66 | 6f 72 6d 2c 20 72 65 63 |pecial f|orm, rec|
|00000f50| 75 72 73 65 0d 09 09 09 | 09 28 69 66 20 28 6f 72 |urse....|.(if (or|
|00000f60| 20 28 65 71 20 28 63 61 | 72 20 66 29 20 27 63 6f | (eq (ca|r f) 'co|
|00000f70| 6d 6d 6f 6e 2d 6c 69 73 | 70 3a 3a 70 72 6f 67 6e |mmon-lis|p::progn|
|00000f80| 29 20 0d 09 09 09 09 09 | 09 28 65 71 20 28 63 61 |) ......|.(eq (ca|
|00000f90| 72 20 66 29 20 27 63 6f | 6d 6d 6f 6e 2d 6c 69 73 |r f) 'co|mmon-lis|
|00000fa0| 70 3a 3a 6c 6f 63 61 6c | 6c 79 29 29 0d 09 09 09 |p::local|ly))....|
|00000fb0| 09 09 28 70 72 6f 67 6e | 0d 09 09 09 09 09 09 28 |..(progn|.......(|
|00000fc0| 70 72 6f 63 65 73 73 2d | 74 6f 70 2d 6c 65 76 65 |process-|top-leve|
|00000fd0| 6c 2d 66 6f 72 6d 73 20 | 28 63 64 72 20 66 29 29 |l-forms |(cdr f))|
|00000fe0| 0d 09 09 09 09 09 09 28 | 67 6f 20 63 6f 6e 74 69 |.......(|go conti|
|00000ff0| 6e 75 65 29 29 29 0d 0d | 09 09 09 09 3b 3b 20 69 |nue)))..|....;; i|
|00001000| 66 20 63 6f 6d 70 69 6c | 65 72 2d 6c 65 74 2c 20 |f compil|er-let, |
|00001010| 6d 61 63 72 6f 6c 65 74 | 20 6f 72 20 73 79 6d 62 |macrolet| or symb|
|00001020| 6f 6c 2d 6d 61 63 72 6f | 6c 65 74 0d 09 09 09 09 |ol-macro|let.....|
|00001030| 28 69 66 20 28 6f 72 20 | 28 65 71 20 28 63 61 72 |(if (or |(eq (car|
|00001040| 20 66 29 20 27 63 6f 6d | 6d 6f 6e 2d 6c 69 73 70 | f) 'com|mon-lisp|
|00001050| 3a 3a 63 6f 6d 70 69 6c | 65 72 2d 6c 65 74 29 0d |::compil|er-let).|
|00001060| 09 09 09 09 09 09 28 65 | 71 20 28 63 61 72 20 66 |......(e|q (car f|
|00001070| 29 20 27 63 6f 6d 6d 6f | 6e 2d 6c 69 73 70 3a 3a |) 'commo|n-lisp::|
|00001080| 6d 61 63 72 6f 6c 65 74 | 29 20 20 0d 09 09 09 09 |macrolet|) .....|
|00001090| 09 09 28 65 71 20 28 63 | 61 72 20 66 29 20 27 63 |..(eq (c|ar f) 'c|
|000010a0| 6f 6d 6d 6f 6e 2d 6c 69 | 73 70 3a 3a 73 79 6d 62 |ommon-li|sp::symb|
|000010b0| 6f 6c 2d 6d 61 63 72 6f | 6c 65 74 29 29 0d 09 09 |ol-macro|let))...|
|000010c0| 09 09 09 28 70 72 6f 67 | 6e 0d 09 09 09 09 09 09 |...(prog|n.......|
|000010d0| 28 65 72 72 6f 72 20 22 | 43 6f 6d 70 69 6c 65 72 |(error "|Compiler|
|000010e0| 20 64 6f 65 73 20 6e 6f | 74 20 73 75 70 70 6f 72 | does no|t suppor|
|000010f0| 74 20 73 70 65 63 69 61 | 6c 20 66 6f 72 6d 3a 20 |t specia|l form: |
|00001100| 7e 41 22 20 28 63 61 72 | 20 66 29 29 0d 09 09 09 |~A" (car| f))....|
|00001110| 09 09 09 28 70 72 6f 63 | 65 73 73 2d 74 6f 70 2d |...(proc|ess-top-|
|00001120| 6c 65 76 65 6c 2d 66 6f | 72 6d 73 20 28 63 64 72 |level-fo|rms (cdr|
|00001130| 20 66 29 29 0d 09 09 09 | 09 09 09 28 67 6f 20 63 | f))....|...(go c|
|00001140| 6f 6e 74 69 6e 75 65 29 | 29 29 0d 09 0d 09 09 09 |ontinue)|))......|
|00001150| 09 3b 3b 20 69 66 20 65 | 76 61 6c 2d 77 68 65 6e |.;; if e|val-when|
|00001160| 0d 09 09 09 09 28 69 66 | 20 28 65 71 20 28 63 61 |.....(if| (eq (ca|
|00001170| 72 20 66 29 20 27 63 6f | 6d 6d 6f 6e 2d 6c 69 73 |r f) 'co|mmon-lis|
|00001180| 70 3a 3a 65 76 61 6c 2d | 77 68 65 6e 29 0d 09 09 |p::eval-|when)...|
|00001190| 09 09 09 28 70 72 6f 67 | 6e 0d 09 09 09 09 09 09 |...(prog|n.......|
|000011a0| 28 63 6f 6d 70 69 6c 65 | 2d 74 6f 70 2d 6c 65 76 |(compile|-top-lev|
|000011b0| 65 6c 2d 65 76 61 6c 2d | 77 68 65 6e 2d 66 6f 72 |el-eval-|when-for|
|000011c0| 6d 20 66 29 0d 09 09 09 | 09 09 09 28 67 6f 20 63 |m f)....|...(go c|
|000011d0| 6f 6e 74 69 6e 75 65 29 | 29 29 29 29 0d 0d 09 09 |ontinue)|))))....|
|000011e0| 3b 3b 20 65 6c 73 65 20 | 69 74 20 69 73 20 6e 6f |;; else |it is no|
|000011f0| 74 20 61 20 73 70 65 63 | 69 61 6c 20 63 61 73 65 |t a spec|ial case|
|00001200| 0d 0d 09 09 3b 3b 20 6e | 6f 77 20 63 6f 6d 70 69 |....;; n|ow compi|
|00001210| 6c 65 20 69 74 0d 09 09 | 28 73 65 74 71 20 63 6f |le it...|(setq co|
|00001220| 64 65 20 28 63 6f 6d 70 | 69 6c 65 2d 74 6f 70 2d |de (comp|ile-top-|
|00001230| 6c 65 76 65 6c 2d 66 6f | 72 6d 20 66 29 29 0d 09 |level-fo|rm f))..|
|00001240| 09 28 25 77 72 69 74 65 | 2d 63 6f 64 65 2d 74 6f |.(%write|-code-to|
|00001250| 2d 73 74 72 65 61 6d 20 | 63 6f 64 65 20 2a 63 6f |-stream |code *co|
|00001260| 6d 70 69 6c 65 2d 6f 75 | 74 70 75 74 2d 66 69 6c |mpile-ou|tput-fil|
|00001270| 65 2a 20 2a 73 79 6d 62 | 6f 6c 2d 74 61 62 6c 65 |e* *symb|ol-table|
|00001280| 2a 29 0d 0d 09 09 3b 3b | 20 65 76 61 6c 75 61 74 |*)....;;| evaluat|
|00001290| 65 20 74 68 65 20 66 6f | 72 6d 20 69 66 20 63 6f |e the fo|rm if co|
|000012a0| 6d 70 69 6c 65 2d 74 69 | 6d 65 2d 74 6f 6f 20 6d |mpile-ti|me-too m|
|000012b0| 6f 64 65 0d 09 09 28 69 | 66 20 2a 63 6f 6d 70 69 |ode...(i|f *compi|
|000012c0| 6c 65 2d 74 69 6d 65 2d | 74 6f 6f 2d 6d 6f 64 65 |le-time-|too-mode|
|000012d0| 2a 0d 09 09 09 28 73 65 | 74 71 20 72 65 74 75 72 |*....(se|tq retur|
|000012e0| 6e 2d 76 61 6c 75 65 20 | 28 66 75 6e 63 61 6c 6c |n-value |(funcall|
|000012f0| 20 63 6f 64 65 29 29 29 | 0d 0d 63 6f 6e 74 69 6e | code)))|..contin|
|00001300| 75 65 0d 09 09 28 69 66 | 20 70 72 69 6e 74 2d 66 |ue...(if| print-f|
|00001310| 6f 72 6d 0d 09 09 20 09 | 28 70 72 6f 67 6e 0d 09 |orm... .|(progn..|
|00001320| 09 09 09 28 66 6f 72 6d | 61 74 20 74 20 22 7e 41 |...(form|at t "~A|
|00001330| 7e 25 22 20 70 72 69 6e | 74 2d 66 6f 72 6d 29 0d |~%" prin|t-form).|
|00001340| 09 09 09 09 28 66 69 6c | 65 2d 66 6c 75 73 68 29 |....(fil|e-flush)|
|00001350| 29 29 29 29 0d 0d 28 64 | 65 66 75 6e 20 63 6f 6d |))))..(d|efun com|
|00001360| 70 69 6c 65 2d 74 6f 70 | 2d 6c 65 76 65 6c 2d 65 |pile-top|-level-e|
|00001370| 76 61 6c 2d 77 68 65 6e | 2d 66 6f 72 6d 20 28 66 |val-when|-form (f|
|00001380| 6f 72 6d 29 0d 09 28 69 | 66 20 28 6f 72 20 28 6e |orm)..(i|f (or (n|
|00001390| 6f 74 20 28 63 6f 6e 73 | 70 20 66 6f 72 6d 29 29 |ot (cons|p form))|
|000013a0| 20 28 3c 20 28 6c 65 6e | 67 74 68 20 66 6f 72 6d | (< (len|gth form|
|000013b0| 29 20 32 29 20 28 6e 6f | 74 20 28 6c 69 73 74 70 |) 2) (no|t (listp|
|000013c0| 20 28 63 61 64 72 20 66 | 6f 72 6d 29 29 29 29 0d | (cadr f|orm)))).|
|000013d0| 09 09 28 65 72 72 6f 72 | 20 22 27 65 76 61 6c 2d |..(error| "'eval-|
|000013e0| 77 68 65 6e 27 20 66 6f | 72 6d 20 6d 69 73 73 69 |when' fo|rm missi|
|000013f0| 6e 67 20 63 6f 6e 64 69 | 74 69 6f 6e 20 6c 69 73 |ng condi|tion lis|
|00001400| 74 2e 22 29 29 0d 0d 09 | 28 6c 65 74 2a 20 28 28 |t."))...|(let* ((|
|00001410| 63 6f 6e 64 69 74 69 6f | 6e 73 20 28 63 61 64 72 |conditio|ns (cadr|
|00001420| 20 66 6f 72 6d 29 29 0d | 09 09 20 20 20 28 6c 6f | form)).|.. (lo|
|00001430| 61 64 2d 63 6f 6e 64 69 | 74 69 6f 6e 20 0d 09 09 |ad-condi|tion ...|
|00001440| 09 28 6f 72 20 28 6d 65 | 6d 62 65 72 20 27 63 6f |.(or (me|mber 'co|
|00001450| 6d 6d 6f 6e 2d 6c 69 73 | 70 3a 3a 6c 6f 61 64 20 |mmon-lis|p::load |
|00001460| 63 6f 6e 64 69 74 69 6f | 6e 73 29 20 0d 09 09 09 |conditio|ns) ....|
|00001470| 09 28 6d 65 6d 62 65 72 | 20 3a 6c 6f 61 64 2d 74 |.(member| :load-t|
|00001480| 6f 70 6c 65 76 65 6c 20 | 63 6f 6e 64 69 74 69 6f |oplevel |conditio|
|00001490| 6e 73 29 29 29 0d 09 09 | 20 20 20 28 65 76 61 6c |ns)))...| (eval|
|000014a0| 2d 63 6f 6e 64 69 74 69 | 6f 6e 20 0d 09 09 09 28 |-conditi|on ....(|
|000014b0| 6f 72 20 28 6d 65 6d 62 | 65 72 20 27 63 6f 6d 6d |or (memb|er 'comm|
|000014c0| 6f 6e 2d 6c 69 73 70 3a | 3a 65 76 61 6c 20 63 6f |on-lisp:|:eval co|
|000014d0| 6e 64 69 74 69 6f 6e 73 | 29 20 0d 09 09 09 09 28 |nditions|) .....(|
|000014e0| 6d 65 6d 62 65 72 20 3a | 65 78 65 63 75 74 65 20 |member :|execute |
|000014f0| 63 6f 6e 64 69 74 69 6f | 6e 73 29 29 29 0d 09 09 |conditio|ns)))...|
|00001500| 20 20 20 28 63 6f 6d 70 | 69 6c 65 2d 63 6f 6e 64 | (comp|ile-cond|
|00001510| 69 74 69 6f 6e 20 0d 09 | 09 09 28 6f 72 20 28 6d |ition ..|..(or (m|
|00001520| 65 6d 62 65 72 20 27 63 | 6f 6d 6d 6f 6e 2d 6c 69 |ember 'c|ommon-li|
|00001530| 73 70 3a 3a 63 6f 6d 70 | 69 6c 65 20 63 6f 6e 64 |sp::comp|ile cond|
|00001540| 69 74 69 6f 6e 73 29 20 | 0d 09 09 09 09 28 6d 65 |itions) |.....(me|
|00001550| 6d 62 65 72 20 3a 63 6f | 6d 70 69 6c 65 2d 74 6f |mber :co|mpile-to|
|00001560| 70 6c 65 76 65 6c 20 63 | 6f 6e 64 69 74 69 6f 6e |plevel c|ondition|
|00001570| 73 29 29 29 29 0d 0d 09 | 09 28 69 66 20 6c 6f 61 |s))))...|.(if loa|
|00001580| 64 2d 63 6f 6e 64 69 74 | 69 6f 6e 0d 09 09 09 28 |d-condit|ion....(|
|00001590| 69 66 20 28 6f 72 20 63 | 6f 6d 70 69 6c 65 2d 63 |if (or c|ompile-c|
|000015a0| 6f 6e 64 69 74 69 6f 6e | 20 0d 09 09 09 09 09 28 |ondition| ......(|
|000015b0| 61 6e 64 20 2a 63 6f 6d | 70 69 6c 65 2d 74 69 6d |and *com|pile-tim|
|000015c0| 65 2d 74 6f 6f 2d 6d 6f | 64 65 2a 20 65 76 61 6c |e-too-mo|de* eval|
|000015d0| 2d 63 6f 6e 64 69 74 69 | 6f 6e 29 29 0d 09 09 09 |-conditi|on))....|
|000015e0| 09 28 6c 65 74 20 28 28 | 2a 63 6f 6d 70 69 6c 65 |.(let ((|*compile|
|000015f0| 2d 74 69 6d 65 2d 74 6f | 6f 2d 6d 6f 64 65 2a 20 |-time-to|o-mode* |
|00001600| 74 29 29 0d 09 09 09 09 | 09 28 70 72 6f 63 65 73 |t)).....|.(proces|
|00001610| 73 2d 74 6f 70 2d 6c 65 | 76 65 6c 2d 66 6f 72 6d |s-top-le|vel-form|
|00001620| 73 20 28 63 64 64 72 20 | 66 6f 72 6d 29 29 29 0d |s (cddr |form))).|
|00001630| 09 09 09 09 28 6c 65 74 | 20 28 28 2a 63 6f 6d 70 |....(let| ((*comp|
|00001640| 69 6c 65 2d 74 69 6d 65 | 2d 74 6f 6f 2d 6d 6f 64 |ile-time|-too-mod|
|00001650| 65 2a 20 6e 69 6c 29 29 | 0d 09 09 09 09 09 28 70 |e* nil))|......(p|
|00001660| 72 6f 63 65 73 73 2d 74 | 6f 70 2d 6c 65 76 65 6c |rocess-t|op-level|
|00001670| 2d 66 6f 72 6d 73 20 28 | 63 64 64 72 20 66 6f 72 |-forms (|cddr for|
|00001680| 6d 29 29 29 29 0d 0d 09 | 09 09 3b 3b 20 6c 6f 61 |m))))...|..;; loa|
|00001690| 64 20 6e 6f 74 20 73 70 | 65 63 69 66 69 65 64 0d |d not sp|ecified.|
|000016a0| 09 09 09 28 69 66 20 28 | 6f 72 20 63 6f 6d 70 69 |...(if (|or compi|
|000016b0| 6c 65 2d 63 6f 6e 64 69 | 74 69 6f 6e 20 0d 09 09 |le-condi|tion ...|
|000016c0| 09 09 09 28 61 6e 64 20 | 2a 63 6f 6d 70 69 6c 65 |...(and |*compile|
|000016d0| 2d 74 69 6d 65 2d 74 6f | 6f 2d 6d 6f 64 65 2a 20 |-time-to|o-mode* |
|000016e0| 65 76 61 6c 2d 63 6f 6e | 64 69 74 69 6f 6e 29 29 |eval-con|dition))|
|000016f0| 0d 09 09 09 09 28 65 76 | 61 6c 20 66 6f 72 6d 29 |.....(ev|al form)|
|00001700| 29 29 29 29 09 09 09 0d | 09 0d 3b 3b 0d 3b 3b 09 |))))....|..;;.;;.|
|00001710| 54 68 65 20 63 6c 65 61 | 6e 75 70 20 66 6f 72 6d |The clea|nup form|
|00001720| 73 20 73 74 61 63 6b 20 | 6e 65 65 64 73 20 74 6f |s stack |needs to|
|00001730| 20 62 65 20 6d 61 69 6e | 74 61 69 6e 65 64 20 66 | be main|tained f|
|00001740| 6f 72 20 75 73 65 20 69 | 6e 20 6e 6f 6e 2d 6c 6f |or use i|n non-lo|
|00001750| 63 61 6c 0d 3b 3b 09 6c | 65 78 69 63 61 6c 6c 79 |cal.;;.l|exically|
|00001760| 20 73 63 6f 70 65 64 20 | 65 78 69 74 20 73 69 74 | scoped |exit sit|
|00001770| 75 61 74 69 6f 6e 73 2e | 20 53 70 65 63 69 66 69 |uations.| Specifi|
|00001780| 63 61 6c 6c 79 2c 20 47 | 4f 20 77 69 74 68 20 61 |cally, G|O with a|
|00001790| 20 74 61 72 67 65 74 20 | 6f 75 74 73 69 64 65 0d | target |outside.|
|000017a0| 3b 3b 09 74 68 65 20 63 | 75 72 72 65 6e 74 20 63 |;;.the c|urrent c|
|000017b0| 6f 6e 73 74 72 75 63 74 | 2c 20 61 6e 64 20 52 45 |onstruct|, and RE|
|000017c0| 54 55 52 4e 2d 46 52 4f | 4d 20 77 68 65 6e 20 65 |TURN-FRO|M when e|
|000017d0| 78 69 74 69 6e 67 20 61 | 6e 20 65 78 74 65 72 6e |xiting a|n extern|
|000017e0| 61 6c 20 63 6f 6e 73 74 | 72 75 63 74 2e 0d 3b 3b |al const|ruct..;;|
|000017f0| 09 4e 6f 74 65 20 74 68 | 61 74 20 54 48 52 4f 57 |.Note th|at THROW|
|00001800| 20 74 61 72 67 65 74 73 | 20 61 72 65 20 64 79 6e | targets| are dyn|
|00001810| 61 6d 69 63 2c 20 6e 6f | 74 20 6c 65 78 69 63 61 |amic, no|t lexica|
|00001820| 6c 2c 20 61 6e 64 20 74 | 68 65 72 65 66 6f 72 65 |l, and t|herefore|
|00001830| 20 63 61 6e 6e 6f 74 0d | 3b 3b 09 62 65 20 68 61 | cannot.|;;.be ha|
|00001840| 6e 64 6c 65 64 20 61 74 | 20 63 6f 6d 70 69 6c 65 |ndled at| compile|
|00001850| 20 74 69 6d 65 2e 20 54 | 68 65 79 20 61 72 65 20 | time. T|hey are |
|00001860| 68 61 6e 64 6c 65 64 20 | 76 69 61 20 61 20 64 69 |handled |via a di|
|00001870| 66 66 65 72 65 6e 74 20 | 6d 65 63 68 61 6e 69 73 |fferent |mechanis|
|00001880| 6d 2c 20 61 0d 3b 09 72 | 75 6e 2d 74 69 6d 65 20 |m, a.;.r|un-time |
|00001890| 73 74 61 63 6b 2e 20 4c | 65 78 69 63 61 6c 6c 79 |stack. L|exically|
|000018a0| 20 73 63 6f 70 65 64 20 | 65 78 69 74 73 20 61 72 | scoped |exits ar|
|000018b0| 65 20 62 65 74 74 65 72 | 20 68 61 6e 64 6c 65 64 |e better| handled|
|000018c0| 20 61 74 20 63 6f 6d 70 | 69 6c 65 20 74 69 6d 65 | at comp|ile time|
|000018d0| 2c 0d 3b 3b 09 62 6f 74 | 68 20 66 6f 72 20 65 66 |,.;;.bot|h for ef|
|000018e0| 66 69 63 69 65 6e 63 79 | 20 28 61 20 62 69 67 20 |ficiency| (a big |
|000018f0| 63 6f 6e 63 65 72 6e 2c | 20 62 65 63 61 75 73 65 |concern,| because|
|00001900| 20 47 4f 20 69 73 20 74 | 68 65 20 70 72 69 6d 61 | GO is t|he prima|
|00001910| 72 79 20 69 74 65 72 61 | 74 69 6f 6e 20 0d 3b 3b |ry itera|tion .;;|
|00001920| 09 66 61 63 69 6c 69 74 | 79 29 20 61 6e 64 20 62 |.facilit|y) and b|
|00001930| 65 63 61 75 73 65 20 74 | 68 65 20 6c 65 78 69 63 |ecause t|he lexic|
|00001940| 61 6c 20 73 63 6f 70 69 | 6e 67 20 69 73 20 63 75 |al scopi|ng is cu|
|00001950| 72 72 65 6e 74 6c 79 20 | 6f 6e 6c 79 20 6b 6e 6f |rrently |only kno|
|00001960| 77 6e 20 61 74 0d 3b 3b | 09 63 6f 6d 70 69 6c 65 |wn at.;;|.compile|
|00001970| 2d 74 69 6d 65 2e 20 49 | 6e 20 6f 74 68 65 72 20 |-time. I|n other |
|00001980| 77 6f 72 64 73 2c 20 61 | 20 72 75 6e 2d 74 69 6d |words, a| run-tim|
|00001990| 65 20 6c 65 78 69 63 61 | 6c 20 65 6e 76 69 72 6f |e lexica|l enviro|
|000019a0| 6e 6d 65 6e 74 20 69 73 | 20 6e 6f 74 20 6d 61 69 |nment is| not mai|
|000019b0| 6e 74 61 69 6e 65 64 0d | 3b 3b 09 66 6f 72 20 63 |ntained.|;;.for c|
|000019c0| 6f 6d 70 69 6c 65 64 20 | 63 6f 64 65 2c 20 61 6e |ompiled |code, an|
|000019d0| 64 20 66 6f 72 20 65 66 | 66 69 63 69 65 6e 63 79 |d for ef|ficiency|
|000019e0| 20 72 65 61 73 6f 6e 73 | 20 69 74 20 77 6f 75 6c | reasons| it woul|
|000019f0| 64 20 62 65 20 62 65 74 | 74 65 72 20 6e 6f 74 20 |d be bet|ter not |
|00001a00| 74 6f 20 68 61 76 65 0d | 3b 3b 09 74 6f 2e 0d 3b |to have.|;;.to..;|
|00001a10| 3b 0d 3b 3b 09 45 6e 74 | 72 69 65 73 20 6f 6e 20 |;.;;.Ent|ries on |
|00001a20| 74 68 65 20 63 6c 65 61 | 6e 75 70 20 66 6f 72 6d |the clea|nup form|
|00001a30| 73 20 73 74 61 63 6b 20 | 69 6e 63 6c 75 64 65 3a |s stack |include:|
|00001a40| 0d 3b 3b 0d 3b 3b 09 28 | 42 4c 4f 43 4b 20 62 6c |.;;.;;.(|BLOCK bl|
|00001a50| 6f 63 6b 2d 6e 61 6d 65 | 20 62 6c 6f 63 6b 2d 65 |ock-name| block-e|
|00001a60| 78 69 74 2d 6c 61 62 65 | 6c 29 0d 3b 3b 09 28 54 |xit-labe|l).;;.(T|
|00001a70| 41 47 42 4f 44 59 20 28 | 6c 6f 63 61 6c 2d 74 61 |AGBODY (|local-ta|
|00001a80| 67 2d 31 20 2e 20 6c 6f | 63 61 6c 2d 6c 61 62 65 |g-1 . lo|cal-labe|
|00001a90| 6c 2d 31 29 20 28 6c 6f | 63 61 6c 2d 74 61 67 2d |l-1) (lo|cal-tag-|
|00001aa0| 32 20 2e 20 6c 6f 63 61 | 6c 2d 6c 61 62 65 6c 2d |2 . loca|l-label-|
|00001ab0| 32 29 20 2e 2e 2e 29 0d | 3b 3b 09 28 4c 45 54 20 |2) ...).|;;.(LET |
|00001ac0| 28 6c 6f 63 61 6c 2d 76 | 61 72 2d 31 20 2e 20 69 |(local-v|ar-1 . i|
|00001ad0| 6e 64 65 78 31 29 20 28 | 6c 6f 63 61 6c 2d 76 61 |ndex1) (|local-va|
|00001ae0| 72 2d 32 20 2e 20 69 6e | 64 65 78 32 29 20 2e 2e |r-2 . in|dex2) ..|
|00001af0| 2e 29 0d 3b 3b 09 09 28 | 74 68 65 20 4c 45 54 20 |.).;;..(|the LET |
|00001b00| 66 6f 72 6d 20 69 73 20 | 75 73 65 64 20 62 79 20 |form is |used by |
|00001b10| 62 6f 74 68 20 4c 45 54 | 20 2a 61 6e 64 2a 20 4c |both LET| *and* L|
|00001b20| 45 54 2a 20 66 6f 72 6d | 73 29 0d 3b 3b 09 28 43 |ET* form|s).;;.(C|
|00001b30| 41 54 43 48 20 63 61 74 | 63 68 2d 74 61 67 29 0d |ATCH cat|ch-tag).|
|00001b40| 3b 3b 09 28 55 4e 57 49 | 4e 44 2d 50 52 4f 54 45 |;;.(UNWI|ND-PROTE|
|00001b50| 43 54 20 3c 63 6f 6d 70 | 69 6c 65 64 20 63 6f 64 |CT <comp|iled cod|
|00001b60| 65 20 74 6f 20 62 65 20 | 69 6e 63 6c 75 64 65 64 |e to be |included|
|00001b70| 3e 29 0d 3b 3b 20 0d 0d | 28 64 65 66 63 6f 6e 73 |>).;; ..|(defcons|
|00001b80| 74 61 6e 74 20 2a 6c 61 | 6d 62 64 61 2d 6c 69 73 |tant *la|mbda-lis|
|00001b90| 74 2d 6b 65 79 77 6f 72 | 64 73 2a 20 0d 09 09 27 |t-keywor|ds* ...'|
|00001ba0| 28 09 26 6f 70 74 69 6f | 6e 61 6c 20 0d 09 09 09 |(.&optio|nal ....|
|00001bb0| 26 72 65 73 74 20 0d 09 | 09 09 26 6b 65 79 20 0d |&rest ..|..&key .|
|00001bc0| 09 09 09 26 61 75 78 20 | 0d 09 09 09 26 61 6c 6c |...&aux |....&all|
|00001bd0| 6f 77 2d 6f 74 68 65 72 | 2d 6b 65 79 73 0d 09 09 |ow-other|-keys...|
|00001be0| 09 26 77 68 6f 6c 65 0d | 09 09 09 26 62 6f 64 79 |.&whole.|...&body|
|00001bf0| 20 29 29 0d 0d 3b 3b 20 | 74 68 65 20 66 6f 6c 6c | ))..;; |the foll|
|00001c00| 6f 77 69 6e 67 20 61 72 | 65 6e 27 74 20 61 6c 6c |owing ar|en't all|
|00001c10| 6f 77 65 64 20 69 6e 20 | 6c 61 6d 62 64 61 20 66 |owed in |lambda f|
|00001c20| 75 6e 63 74 69 6f 6e 20 | 64 65 63 6c 61 72 61 74 |unction |declarat|
|00001c30| 69 6f 6e 73 0d 3b 3b 20 | 28 6f 6e 6c 79 20 69 6e |ions.;; |(only in|
|00001c40| 20 6d 61 63 72 6f 73 2c | 20 77 68 69 63 68 20 77 | macros,| which w|
|00001c50| 69 6c 6c 20 62 65 20 65 | 78 70 61 6e 64 65 64 20 |ill be e|xpanded |
|00001c60| 62 65 66 6f 72 65 20 77 | 65 20 73 65 65 20 74 68 |before w|e see th|
|00001c70| 65 6d 29 0d 28 64 65 66 | 63 6f 6e 73 74 61 6e 74 |em).(def|constant|
|00001c80| 20 2a 75 6e 73 75 70 70 | 6f 72 74 65 64 2d 6c 61 | *unsupp|orted-la|
|00001c90| 6d 62 64 61 2d 6c 69 73 | 74 2d 6b 65 79 77 6f 72 |mbda-lis|t-keywor|
|00001ca0| 64 73 2a 20 0d 09 09 27 | 28 20 20 26 61 6c 6c 6f |ds* ...'|( &allo|
|00001cb0| 77 2d 6f 74 68 65 72 2d | 6b 65 79 73 0d 09 09 09 |w-other-|keys....|
|00001cc0| 26 77 68 6f 6c 65 0d 09 | 09 09 26 62 6f 64 79 20 |&whole..|..&body |
|00001cd0| 29 29 0d 0d 3b 3b 0d 3b | 3b 09 53 65 74 20 75 70 |))..;;.;|;.Set up|
|00001ce0| 20 73 71 75 61 72 65 20 | 62 72 61 63 65 73 20 61 | square |braces a|
|00001cf0| 73 20 61 73 73 65 6d 62 | 6c 79 20 64 65 6c 69 6d |s assemb|ly delim|
|00001d00| 69 74 65 72 73 20 66 6f | 72 20 74 68 69 73 20 6d |iters fo|r this m|
|00001d10| 6f 64 75 6c 65 0d 3b 3b | 09 54 68 69 73 20 68 65 |odule.;;|.This he|
|00001d20| 6c 70 73 20 74 6f 20 63 | 6c 65 61 72 6c 79 20 64 |lps to c|learly d|
|00001d30| 69 73 74 69 6e 67 75 69 | 73 68 20 74 68 65 20 67 |istingui|sh the g|
|00001d40| 65 6e 65 72 61 74 65 64 | 20 63 6f 64 65 20 66 72 |enerated| code fr|
|00001d50| 6f 6d 20 74 68 65 0d 3b | 3b 09 73 75 72 72 6f 75 |om the.;|;.surrou|
|00001d60| 6e 64 69 6e 67 20 73 74 | 75 66 66 2e 0d 3b 3b 0d |nding st|uff..;;.|
|00001d70| 28 64 65 66 75 6e 20 70 | 75 73 68 2d 61 73 73 65 |(defun p|ush-asse|
|00001d80| 6d 62 6c 79 2d 69 6e 73 | 74 72 75 63 74 69 6f 6e |mbly-ins|truction|
|00001d90| 73 20 28 26 72 65 73 74 | 20 69 6e 73 74 72 75 63 |s (&rest| instruc|
|00001da0| 74 69 6f 6e 73 29 0d 09 | 28 64 6f 6c 69 73 74 20 |tions)..|(dolist |
|00001db0| 28 78 20 69 6e 73 74 72 | 75 63 74 69 6f 6e 73 29 |(x instr|uctions)|
|00001dc0| 0d 09 09 28 70 75 73 68 | 20 78 20 2a 61 73 6d 2a |...(push| x *asm*|
|00001dd0| 29 29 29 0d 0d 28 64 65 | 66 75 6e 20 70 75 73 68 |)))..(de|fun push|
|00001de0| 2d 63 6c 65 61 6e 75 70 | 20 28 78 29 20 28 70 75 |-cleanup| (x) (pu|
|00001df0| 73 68 20 78 20 2a 63 6c | 65 61 6e 75 70 2d 66 6f |sh x *cl|eanup-fo|
|00001e00| 72 6d 73 2d 73 74 61 63 | 6b 2a 29 29 0d 28 64 65 |rms-stac|k*)).(de|
|00001e10| 66 75 6e 20 70 6f 70 2d | 63 6c 65 61 6e 75 70 20 |fun pop-|cleanup |
|00001e20| 28 29 20 28 70 6f 70 20 | 2a 63 6c 65 61 6e 75 70 |() (pop |*cleanup|
|00001e30| 2d 66 6f 72 6d 73 2d 73 | 74 61 63 6b 2a 29 29 0d |-forms-s|tack*)).|
|00001e40| 0d 3b 3b 09 57 65 20 75 | 73 65 20 74 68 65 20 66 |.;;.We u|se the f|
|00001e50| 6f 6c 6c 6f 77 69 6e 67 | 20 72 65 67 69 73 74 65 |ollowing| registe|
|00001e60| 72 73 3a 0d 3b 3b 09 41 | 30 2c 20 44 30 20 3a 20 |rs:.;;.A|0, D0 : |
|00001e70| 73 63 72 61 74 63 68 20 | 72 65 67 69 73 74 65 72 |scratch |register|
|00001e80| 73 2e 20 44 30 20 75 6c | 74 69 6d 61 74 65 6c 79 |s. D0 ul|timately|
|00001e90| 20 72 65 74 75 72 6e 73 | 20 74 68 65 20 76 61 6c | returns| the val|
|00001ea0| 75 65 2e 0d 3b 3b 09 44 | 33 20 3a 20 73 74 6f 72 |ue..;;.D|3 : stor|
|00001eb0| 65 73 20 6c 61 73 74 20 | 72 65 74 75 72 6e 65 64 |es last |returned|
|00001ec0| 20 76 61 6c 75 65 0d 3b | 3b 09 41 32 20 3a 20 75 | value.;|;.A2 : u|
|00001ed0| 73 65 64 20 61 73 20 6c | 6f 63 61 6c 20 69 6e 64 |sed as l|ocal ind|
|00001ee0| 65 78 20 66 6f 72 20 66 | 75 6e 63 74 69 6f 6e 20 |ex for f|unction |
|00001ef0| 63 61 6c 6c 0d 3b 3b 09 | 41 33 20 3a 20 70 6f 69 |call.;;.|A3 : poi|
|00001f00| 6e 74 73 20 74 6f 20 6c | 65 78 69 63 61 6c 20 73 |nts to l|exical s|
|00001f10| 74 6f 72 61 67 65 20 66 | 6f 72 20 74 68 65 20 66 |torage f|or the f|
|00001f20| 75 6e 63 74 69 6f 6e 0d | 3b 3b 09 41 34 20 3a 20 |unction.|;;.A4 : |
|00001f30| 70 6f 69 6e 74 73 20 74 | 6f 20 66 75 6e 63 74 69 |points t|o functi|
|00001f40| 6f 6e 27 73 20 65 6e 76 | 69 72 6f 6e 6d 65 6e 74 |on's env|ironment|
|00001f50| 20 28 76 61 72 69 61 62 | 6c 65 73 20 77 69 74 68 | (variab|les with|
|00001f60| 20 69 6e 64 65 66 69 6e | 69 74 65 20 65 78 74 65 | indefin|ite exte|
|00001f70| 6e 74 29 0d 3b 3b 09 41 | 36 20 3a 20 6c 69 6e 6b |nt).;;.A|6 : link|
|00001f80| 73 20 70 72 65 76 69 6f | 75 73 20 73 74 61 63 6b |s previo|us stack|
|00001f90| 20 66 72 61 6d 65 0d 3b | 3b 09 41 37 20 3a 20 73 | frame.;|;.A7 : s|
|00001fa0| 74 61 63 6b 20 70 6f 69 | 6e 74 65 72 0d 3b 3b 09 |tack poi|nter.;;.|
|00001fb0| 41 35 20 3a 20 67 6c 6f | 62 61 6c 20 76 61 72 69 |A5 : glo|bal vari|
|00001fc0| 61 62 6c 65 73 0d 3b 3b | 09 0d 3b 3b 09 57 65 20 |ables.;;|..;;.We |
|00001fd0| 64 6f 20 6e 6f 74 20 6e | 65 65 64 20 74 6f 20 73 |do not n|eed to s|
|00001fe0| 61 76 65 20 41 35 2c 20 | 41 36 20 6f 72 20 41 37 |ave A5, |A6 or A7|
|00001ff0| 0d 3b 3b 09 57 65 20 61 | 6c 73 6f 20 64 6f 6e 27 |.;;.We a|lso don'|
|00002000| 74 20 6e 65 65 64 20 74 | 6f 20 73 61 76 65 20 73 |t need t|o save s|
|00002010| 63 72 61 74 63 68 20 72 | 65 67 69 73 74 65 72 20 |cratch r|egister |
|00002020| 44 30 2e 0d 3b 3b 09 57 | 65 20 2a 64 6f 2a 20 6e |D0..;;.W|e *do* n|
|00002030| 65 65 64 20 74 6f 20 73 | 61 76 65 20 41 30 2c 20 |eed to s|ave A0, |
|00002040| 41 32 2c 20 41 33 20 61 | 6e 64 20 44 33 2e 0d 3b |A2, A3 a|nd D3..;|
|00002050| 3b 0d 09 09 09 0d 3b 3b | 0d 3b 3b 09 63 6f 6d 70 |;.....;;|.;;.comp|
|00002060| 69 6c 65 2d 74 6f 70 2d | 6c 65 76 65 6c 2d 66 6f |ile-top-|level-fo|
|00002070| 72 6d 20 28 66 6f 72 6d | 20 26 6f 70 74 69 6f 6e |rm (form| &option|
|00002080| 61 6c 20 28 61 73 73 65 | 6d 62 6c 65 20 74 29 29 |al (asse|mble t))|
|00002090| 0d 3b 3b 09 47 69 76 65 | 6e 20 61 6e 20 61 72 62 |.;;.Give|n an arb|
|000020a0| 69 74 72 61 72 79 20 6c | 69 73 70 20 66 6f 72 6d |itrary l|isp form|
|000020b0| 2c 20 72 65 74 75 72 6e | 73 20 61 20 63 6f 6d 70 |, return|s a comp|
|000020c0| 69 6c 65 64 20 66 75 6e | 63 74 69 6f 6e 20 0d 3b |iled fun|ction .;|
|000020d0| 3b 09 65 71 75 69 76 61 | 6c 65 6e 74 20 74 6f 20 |;.equiva|lent to |
|000020e0| 69 74 2e 0d 3b 3b 0d 28 | 64 65 66 75 6e 20 63 6f |it..;;.(|defun co|
|000020f0| 6d 70 69 6c 65 2d 74 6f | 70 2d 6c 65 76 65 6c 2d |mpile-to|p-level-|
|00002100| 66 6f 72 6d 20 28 66 6f | 72 6d 29 0d 09 28 6c 65 |form (fo|rm)..(le|
|00002110| 74 2a 20 28 0d 09 09 20 | 20 20 3b 3b 20 45 73 74 |t* (... | ;; Est|
|00002120| 61 62 6c 69 73 68 20 6c | 6f 63 61 6c 20 62 69 6e |ablish l|ocal bin|
|00002130| 64 69 6e 67 73 20 6f 66 | 20 74 68 65 73 65 20 73 |dings of| these s|
|00002140| 70 65 63 69 61 6c 20 76 | 61 72 69 61 62 6c 65 73 |pecial v|ariables|
|00002150| 0d 09 09 20 20 20 3b 3b | 20 73 6f 20 74 68 61 74 |... ;;| so that|
|00002160| 20 74 68 69 73 20 66 75 | 6e 63 74 69 6f 6e 20 63 | this fu|nction c|
|00002170| 61 6e 20 62 65 20 65 6e | 74 65 72 65 64 20 72 65 |an be en|tered re|
|00002180| 63 75 72 73 69 76 65 6c | 79 2e 0d 09 09 20 20 20 |cursivel|y.... |
|00002190| 3b 3b 0d 09 09 20 20 20 | 28 2a 61 73 6d 2a 20 6e |;;... |(*asm* n|
|000021a0| 69 6c 29 0d 09 09 20 20 | 20 28 2a 6c 65 78 2d 63 |il)... | (*lex-c|
|000021b0| 6f 75 6e 74 65 72 2a 20 | 30 29 0d 09 09 20 20 20 |ounter* |0)... |
|000021c0| 28 2a 72 65 66 65 72 65 | 6e 63 65 73 2a 20 6e 69 |(*refere|nces* ni|
|000021d0| 6c 29 0d 09 09 20 20 20 | 28 2a 66 75 6e 63 74 69 |l)... |(*functi|
|000021e0| 6f 6e 2d 65 6e 74 72 79 | 2d 6c 61 62 65 6c 2a 20 |on-entry|-label* |
|000021f0| 28 67 65 6e 73 79 6d 29 | 29 0d 09 09 20 20 20 28 |(gensym)|)... (|
|00002200| 2a 6c 61 73 74 2d 63 61 | 6c 6c 2d 77 61 73 2d 76 |*last-ca|ll-was-v|
|00002210| 61 6c 75 65 73 2a 20 6e | 69 6c 29 0d 09 09 20 20 |alues* n|il)... |
|00002220| 20 28 2a 63 6c 65 61 6e | 75 70 2d 66 6f 72 6d 73 | (*clean|up-forms|
|00002230| 2d 73 74 61 63 6b 2a 20 | 6e 69 6c 29 0d 09 09 20 |-stack* |nil)... |
|00002240| 20 20 28 2a 65 6e 76 69 | 72 6f 6e 6d 65 6e 74 2a | (*envi|ronment*|
|00002250| 20 6e 69 6c 29 0d 09 09 | 20 20 20 28 2a 65 6d 62 | nil)...| (*emb|
|00002260| 65 64 64 65 64 2d 6c 61 | 6d 62 64 61 73 2a 20 28 |edded-la|mbdas* (|
|00002270| 66 69 6e 64 2d 6c 61 6d | 62 64 61 73 20 66 6f 72 |find-lam|bdas for|
|00002280| 6d 29 29 29 09 0d 09 09 | 20 20 20 0d 09 09 3b 3b |m)))....| ...;;|
|00002290| 20 65 6d 69 74 20 63 6f | 64 65 20 66 6f 72 20 66 | emit co|de for f|
|000022a0| 75 6e 63 74 69 6f 6e 20 | 70 72 6f 6c 6f 67 0d 3b |unction |prolog.;|
|000022b0| 3b 09 09 5b 20 60 28 6c | 69 6e 6b 20 61 36 20 2c |;..[ `(l|ink a6 ,|
|000022c0| 28 2d 20 28 2a 20 6e 75 | 6d 61 72 67 73 20 34 29 |(- (* nu|margs 4)|
|000022d0| 29 29 20 5d 20 09 3b 3b | 20 74 68 69 73 20 69 73 |)) ] .;;| this is|
|000022e0| 20 61 64 64 65 64 20 61 | 74 20 65 6e 64 0d 09 09 | added a|t end...|
|000022f0| 28 65 6d 69 74 2d 70 72 | 6f 6c 6f 67 29 0d 09 09 |(emit-pr|olog)...|
|00002300| 09 09 0d 09 09 3b 3b 20 | 63 6f 6d 70 69 6c 65 20 |.....;; |compile |
|00002310| 74 68 65 20 66 6f 72 6d | 0d 09 09 28 63 6f 6d 70 |the form|...(comp|
|00002320| 69 6c 65 2d 66 6f 72 6d | 20 66 6f 72 6d 29 0d 0d |ile-form| form)..|
|00002330| 09 09 3b 3b 20 6d 61 6b | 65 20 73 75 72 65 20 62 |..;; mak|e sure b|
|00002340| 6f 67 75 73 20 6d 75 6c | 74 69 70 6c 65 20 76 61 |ogus mul|tiple va|
|00002350| 6c 75 65 73 20 64 6f 6e | 27 74 20 67 65 74 20 72 |lues don|'t get r|
|00002360| 65 74 75 72 6e 65 64 0d | 09 09 28 75 6e 6c 65 73 |eturned.|..(unles|
|00002370| 73 20 2a 6c 61 73 74 2d | 63 61 6c 6c 2d 77 61 73 |s *last-|call-was|
|00002380| 2d 76 61 6c 75 65 73 2a | 20 28 6b 69 6c 6c 2d 6d |-values*| (kill-m|
|00002390| 75 6c 74 69 70 6c 65 2d | 76 61 6c 75 65 73 29 29 |ultiple-|values))|
|000023a0| 0d 0d 09 09 28 65 6d 69 | 74 2d 65 70 69 6c 6f 67 |....(emi|t-epilog|
|000023b0| 29 09 09 0d 09 09 0d 09 | 09 3b 3b 20 69 66 20 77 |).......|.;; if w|
|000023c0| 65 20 64 6f 6e 27 74 20 | 77 61 6e 74 20 74 6f 20 |e don't |want to |
|000023d0| 61 73 73 65 6d 62 6c 65 | 20 69 74 2c 20 65 78 69 |assemble| it, exi|
|000023e0| 74 20 68 65 72 65 0d 09 | 09 28 69 66 20 2a 61 73 |t here..|.(if *as|
|000023f0| 73 65 6d 62 6c 65 2d 63 | 6f 64 65 2a 20 0d 09 09 |semble-c|ode* ...|
|00002400| 09 28 72 65 74 75 72 6e | 20 28 61 73 73 65 6d 62 |.(return| (assemb|
|00002410| 6c 65 20 2a 61 73 6d 2a | 20 2a 72 65 66 65 72 65 |le *asm*| *refere|
|00002420| 6e 63 65 73 2a 20 6e 69 | 6c 29 29 09 09 09 0d 09 |nces* ni|l)).....|
|00002430| 09 09 28 72 65 74 75 72 | 6e 20 2a 61 73 6d 2a 29 |..(retur|n *asm*)|
|00002440| 29 29 29 0d 0d 0d 3b 3b | 2d 2d 2d 2d 2d 2d 2d 2d |)))...;;|--------|
|00002450| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00002460| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00002470| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 0d 3b 3b 0d 3b |--------|---.;;.;|
|00002480| 3b 09 63 6f 6d 70 69 6c | 65 2d 6c 61 6d 62 64 61 |;.compil|e-lambda|
|00002490| 20 28 6c 61 6d 62 64 61 | 29 0d 3b 3b 09 47 69 76 | (lambda|).;;.Giv|
|000024a0| 65 6e 20 61 20 6c 61 6d | 62 64 61 20 65 78 70 72 |en a lam|bda expr|
|000024b0| 65 73 73 69 6f 6e 2c 20 | 72 65 74 75 72 6e 73 20 |ession, |returns |
|000024c0| 61 20 63 6f 6d 70 69 6c | 65 64 20 66 75 6e 63 74 |a compil|ed funct|
|000024d0| 69 6f 6e 2e 0d 3b 3b 0d | 28 64 65 66 75 6e 20 63 |ion..;;.|(defun c|
|000024e0| 6f 6d 70 69 6c 65 2d 6c | 61 6d 62 64 61 20 28 6c |ompile-l|ambda (l|
|000024f0| 61 6d 62 64 61 20 66 75 | 6e 63 2d 6e 61 6d 65 29 |ambda fu|nc-name)|
|00002500| 0d 09 28 63 68 65 63 6b | 2d 6c 61 6d 62 64 61 20 |..(check|-lambda |
|00002510| 6c 61 6d 62 64 61 29 09 | 09 09 3b 3b 20 6d 61 6b |lambda).|..;; mak|
|00002520| 65 20 73 75 72 65 20 77 | 65 20 63 61 6e 20 63 6f |e sure w|e can co|
|00002530| 6d 70 69 6c 65 20 69 74 | 09 0d 09 28 6c 65 74 2a |mpile it|...(let*|
|00002540| 20 28 28 2a 61 73 6d 2a | 20 6e 69 6c 29 0d 09 09 | ((*asm*| nil)...|
|00002550| 20 20 20 28 2a 72 65 66 | 65 72 65 6e 63 65 73 2a | (*ref|erences*|
|00002560| 20 6e 69 6c 29 0d 09 09 | 20 20 20 28 2a 66 75 6e | nil)...| (*fun|
|00002570| 63 74 69 6f 6e 2d 6e 61 | 6d 65 2a 20 66 75 6e 63 |ction-na|me* func|
|00002580| 2d 6e 61 6d 65 29 0d 09 | 09 20 20 20 28 2a 66 75 |-name)..|. (*fu|
|00002590| 6e 63 74 69 6f 6e 2d 65 | 6e 74 72 79 2d 6c 61 62 |nction-e|ntry-lab|
|000025a0| 65 6c 2a 20 28 67 65 6e | 73 79 6d 29 29 0d 09 09 |el* (gen|sym))...|
|000025b0| 20 20 20 28 2a 63 6c 65 | 61 6e 75 70 2d 66 6f 72 | (*cle|anup-for|
|000025c0| 6d 73 2d 73 74 61 63 6b | 2a 20 6e 69 6c 29 0d 09 |ms-stack|* nil)..|
|000025d0| 09 20 20 20 28 2a 6c 61 | 6d 62 64 61 2d 6c 69 73 |. (*la|mbda-lis|
|000025e0| 74 2a 20 28 63 61 64 72 | 20 6c 61 6d 62 64 61 29 |t* (cadr| lambda)|
|000025f0| 29 0d 09 09 20 20 20 28 | 2a 6c 61 73 74 2d 63 61 |)... (|*last-ca|
|00002600| 6c 6c 2d 77 61 73 2d 76 | 61 6c 75 65 73 2a 20 6e |ll-was-v|alues* n|
|00002610| 69 6c 29 0d 09 09 20 20 | 20 28 2a 65 6e 76 69 72 |il)... | (*envir|
|00002620| 6f 6e 6d 65 6e 74 2a 20 | 2a 65 6e 76 69 72 6f 6e |onment* |*environ|
|00002630| 6d 65 6e 74 2a 29 09 3b | 3b 20 69 6e 68 65 72 69 |ment*).;|; inheri|
|00002640| 74 20 66 72 6f 6d 20 65 | 6e 63 6c 6f 73 69 6e 67 |t from e|nclosing|
|00002650| 20 65 78 70 72 65 73 73 | 69 6f 6e 0d 09 09 20 20 | express|ion... |
|00002660| 20 28 2a 65 6d 62 65 64 | 64 65 64 2d 6c 61 6d 62 | (*embed|ded-lamb|
|00002670| 64 61 73 2a 20 28 66 69 | 6e 64 2d 6c 61 6d 62 64 |das* (fi|nd-lambd|
|00002680| 61 73 20 28 63 64 72 20 | 6c 61 6d 62 64 61 29 29 |as (cdr |lambda))|
|00002690| 29 09 0d 09 09 20 20 20 | 28 2a 61 72 67 2d 63 6f |).... |(*arg-co|
|000026a0| 75 6e 74 2a 20 30 29 0d | 09 09 20 20 20 28 2a 6c |unt* 0).|.. (*l|
|000026b0| 65 78 2d 63 6f 75 6e 74 | 65 72 2a 20 30 29 0d 09 |ex-count|er* 0)..|
|000026c0| 09 20 20 20 28 2a 6c 61 | 6d 62 64 61 2d 73 70 65 |. (*la|mbda-spe|
|000026d0| 63 69 61 6c 2d 76 61 72 | 73 2a 20 6e 69 6c 29 0d |cial-var|s* nil).|
|000026e0| 09 09 20 20 20 28 2a 6c | 61 6d 62 64 61 2d 64 65 |.. (*l|ambda-de|
|000026f0| 63 6c 61 72 61 74 69 6f | 6e 73 2a 20 6e 69 6c 29 |claratio|ns* nil)|
|00002700| 09 09 09 0d 09 09 20 20 | 20 28 2a 6c 61 6d 62 64 |...... | (*lambd|
|00002710| 61 2d 73 70 65 63 69 61 | 6c 2d 64 65 63 73 2a 20 |a-specia|l-decs* |
|00002720| 6e 69 6c 29 0d 09 09 20 | 20 20 28 2a 6c 61 73 74 |nil)... | (*last|
|00002730| 2d 63 61 6c 6c 2d 77 61 | 73 2d 74 61 69 6c 2d 72 |-call-wa|s-tail-r|
|00002740| 65 63 75 72 73 69 6f 6e | 2a 20 6e 69 6c 29 09 09 |ecursion|* nil)..|
|00002750| 09 0d 09 09 20 20 20 28 | 66 6f 72 6d 73 20 28 63 |.... (|forms (c|
|00002760| 64 64 72 20 6c 61 6d 62 | 64 61 29 29 0d 09 09 20 |ddr lamb|da))... |
|00002770| 20 20 28 6e 65 77 2d 76 | 61 72 73 20 28 63 6f 6c | (new-v|ars (col|
|00002780| 6c 65 63 74 2d 6e 65 77 | 2d 76 61 72 73 20 2a 6c |lect-new|-vars *l|
|00002790| 61 6d 62 64 61 2d 6c 69 | 73 74 2a 29 29 0d 09 09 |ambda-li|st*))...|
|000027a0| 20 20 20 28 6c 65 78 2d | 76 61 72 73 20 6e 69 6c | (lex-|vars nil|
|000027b0| 29 0d 09 09 20 20 20 28 | 61 75 78 2d 61 72 67 73 |)... (|aux-args|
|000027c0| 20 28 61 75 78 2d 61 72 | 67 75 6d 65 6e 74 73 20 | (aux-ar|guments |
|000027d0| 2a 6c 61 6d 62 64 61 2d | 6c 69 73 74 2a 29 29 29 |*lambda-|list*)))|
|000027e0| 0d 0d 09 09 3b 3b 20 6c | 6f 6f 6b 20 66 6f 72 20 |....;; l|ook for |
|000027f0| 64 65 63 6c 61 72 61 74 | 69 6f 6e 73 0d 09 09 28 |declarat|ions...(|
|00002800| 64 6f 20 28 28 66 20 66 | 6f 72 6d 73 20 28 63 64 |do ((f f|orms (cd|
|00002810| 72 20 66 29 29 29 0d 09 | 09 09 28 28 6e 75 6c 6c |r f)))..|..((null|
|00002820| 20 66 29 20 28 73 65 74 | 71 20 66 6f 72 6d 73 20 | f) (set|q forms |
|00002830| 66 29 29 0d 09 09 09 28 | 69 66 20 28 61 6e 64 20 |f))....(|if (and |
|00002840| 28 63 6f 6e 73 70 20 28 | 63 61 72 20 66 29 29 20 |(consp (|car f)) |
|00002850| 28 65 71 20 28 63 61 61 | 72 20 66 29 20 27 64 65 |(eq (caa|r f) 'de|
|00002860| 63 6c 61 72 65 29 29 0d | 09 09 09 09 28 70 75 73 |clare)).|....(pus|
|00002870| 68 20 28 63 61 72 20 66 | 29 20 2a 6c 61 6d 62 64 |h (car f|) *lambd|
|00002880| 61 2d 64 65 63 6c 61 72 | 61 74 69 6f 6e 73 2a 29 |a-declar|ations*)|
|00002890| 0d 09 09 09 09 28 70 72 | 6f 67 6e 20 28 73 65 74 |.....(pr|ogn (set|
|000028a0| 71 20 66 6f 72 6d 73 20 | 66 29 20 28 72 65 74 75 |q forms |f) (retu|
|000028b0| 72 6e 29 29 29 29 0d 0d | 09 09 3b 3b 20 73 65 61 |rn))))..|..;; sea|
|000028c0| 72 63 68 20 64 65 63 6c | 61 72 61 74 69 6f 6e 73 |rch decl|arations|
|000028d0| 20 66 6f 72 20 73 70 65 | 63 69 61 6c 20 64 65 63 | for spe|cial dec|
|000028e0| 6c 61 72 61 74 69 6f 6e | 73 0d 09 09 28 64 6f 6c |laration|s...(dol|
|000028f0| 69 73 74 20 28 64 65 63 | 6c 61 72 61 74 69 6f 6e |ist (dec|laration|
|00002900| 20 2a 6c 61 6d 62 64 61 | 2d 64 65 63 6c 61 72 61 | *lambda|-declara|
|00002910| 74 69 6f 6e 73 2a 29 0d | 09 09 09 28 64 6f 6c 69 |tions*).|...(doli|
|00002920| 73 74 20 28 64 65 63 2d | 66 6f 72 6d 20 28 63 64 |st (dec-|form (cd|
|00002930| 72 20 64 65 63 6c 61 72 | 61 74 69 6f 6e 29 29 0d |r declar|ation)).|
|00002940| 09 09 09 09 28 69 66 20 | 28 61 6e 64 20 28 63 6f |....(if |(and (co|
|00002950| 6e 73 70 20 64 65 63 2d | 66 6f 72 6d 29 20 28 65 |nsp dec-|form) (e|
|00002960| 71 20 28 63 61 72 20 64 | 65 63 2d 66 6f 72 6d 29 |q (car d|ec-form)|
|00002970| 20 27 73 70 65 63 69 61 | 6c 29 29 0d 09 09 09 09 | 'specia|l)).....|
|00002980| 09 28 73 65 74 71 20 2a | 6c 61 6d 62 64 61 2d 73 |.(setq *|lambda-s|
|00002990| 70 65 63 69 61 6c 2d 64 | 65 63 73 2a 0d 09 09 09 |pecial-d|ecs*....|
|000029a0| 09 09 09 28 61 70 70 65 | 6e 64 20 28 63 64 72 20 |...(appe|nd (cdr |
|000029b0| 64 65 63 2d 66 6f 72 6d | 29 20 2a 6c 61 6d 62 64 |dec-form|) *lambd|
|000029c0| 61 2d 73 70 65 63 69 61 | 6c 2d 64 65 63 73 2a 29 |a-specia|l-decs*)|
|000029d0| 29 29 29 29 0d 0d 09 09 | 28 73 65 74 71 20 6c 65 |))))....|(setq le|
|000029e0| 78 2d 76 61 72 73 20 0d | 09 09 09 28 72 65 6d 6f |x-vars .|...(remo|
|000029f0| 76 65 2d 69 66 20 0d 09 | 09 09 09 23 27 28 6c 61 |ve-if ..|...#'(la|
|00002a00| 6d 62 64 61 20 28 78 29 | 20 0d 09 09 09 09 09 28 |mbda (x)| ......(|
|00002a10| 6f 72 20 28 6d 65 6d 62 | 65 72 20 78 20 2a 6c 61 |or (memb|er x *la|
|00002a20| 6d 62 64 61 2d 73 70 65 | 63 69 61 6c 2d 64 65 63 |mbda-spe|cial-dec|
|00002a30| 73 2a 29 0d 09 09 09 09 | 09 09 28 73 70 65 63 69 |s*).....|..(speci|
|00002a40| 61 6c 2d 76 61 72 69 61 | 62 6c 65 2d 70 20 78 29 |al-varia|ble-p x)|
|00002a50| 29 29 0d 09 09 09 09 6e | 65 77 2d 76 61 72 73 0d |)).....n|ew-vars.|
|00002a60| 09 09 09 09 3a 6b 65 79 | 20 23 27 63 61 72 29 29 |....:key| #'car))|
|00002a70| 0d 0d 09 09 28 61 64 64 | 2d 6c 65 78 69 63 61 6c |....(add|-lexical|
|00002a80| 2d 76 61 72 69 61 62 6c | 65 73 20 6c 65 78 2d 76 |-variabl|es lex-v|
|00002a90| 61 72 73 29 0d 0d 09 09 | 28 65 6d 69 74 2d 70 72 |ars)....|(emit-pr|
|00002aa0| 6f 6c 6f 67 29 0d 09 09 | 28 63 6f 6d 70 69 6c 65 |olog)...|(compile|
|00002ab0| 2d 6c 61 6d 62 64 61 2d | 61 72 67 73 29 0d 09 09 |-lambda-|args)...|
|00002ac0| 28 63 72 65 61 74 65 2d | 72 75 6e 74 69 6d 65 2d |(create-|runtime-|
|00002ad0| 62 69 6e 64 69 6e 67 73 | 29 09 3b 3b 20 63 72 65 |bindings|).;; cre|
|00002ae0| 61 74 65 20 6e 65 63 65 | 73 73 61 72 79 20 68 65 |ate nece|ssary he|
|00002af0| 61 70 20 62 69 6e 64 69 | 6e 67 73 0d 09 09 0d 09 |ap bindi|ngs.....|
|00002b00| 09 3b 3b 20 68 61 6e 64 | 6c 65 20 61 75 78 20 76 |.;; hand|le aux v|
|00002b10| 61 72 69 61 62 6c 65 73 | 20 62 79 20 6a 75 73 74 |ariables| by just|
|00002b20| 20 61 64 64 69 6e 67 20 | 61 6e 20 69 6d 70 6c 69 | adding |an impli|
|00002b30| 63 69 74 20 6c 65 74 2a | 20 66 6f 72 6d 0d 09 09 |cit let*| form...|
|00002b40| 28 69 66 20 61 75 78 2d | 61 72 67 73 0d 09 09 09 |(if aux-|args....|
|00002b50| 28 73 65 74 66 20 66 6f | 72 6d 73 20 60 28 28 6c |(setf fo|rms `((l|
|00002b60| 65 74 2a 20 2c 61 75 78 | 2d 61 72 67 73 20 2c 40 |et* ,aux|-args ,@|
|00002b70| 66 6f 72 6d 73 29 29 29 | 29 0d 09 09 09 0d 09 09 |forms)))|).......|
|00002b80| 28 63 6f 6d 70 69 6c 65 | 2d 6e 69 6c 29 09 09 3b |(compile|-nil)..;|
|00002b90| 3b 20 73 74 6f 72 65 20 | 4e 49 4c 20 61 73 20 64 |; store |NIL as d|
|00002ba0| 65 66 61 75 6c 74 20 72 | 65 74 75 72 6e 20 76 61 |efault r|eturn va|
|00002bb0| 6c 75 65 0d 09 09 09 09 | 0d 0d 09 09 28 69 66 20 |lue.....|....(if |
|00002bc0| 2a 6c 61 6d 62 64 61 2d | 73 70 65 63 69 61 6c 2d |*lambda-|special-|
|00002bd0| 76 61 72 73 2a 0d 09 09 | 09 28 63 6f 6d 70 69 6c |vars*...|.(compil|
|00002be0| 65 2d 75 6e 77 69 6e 64 | 2d 70 72 6f 74 65 63 74 |e-unwind|-protect|
|00002bf0| 2d 66 6f 72 6d 20 0d 09 | 09 09 09 60 28 75 6e 77 |-form ..|...`(unw|
|00002c00| 69 6e 64 2d 70 72 6f 74 | 65 63 74 20 0d 09 09 09 |ind-prot|ect ....|
|00002c10| 09 09 28 62 6c 6f 63 6b | 20 2c 66 75 6e 63 2d 6e |..(block| ,func-n|
|00002c20| 61 6d 65 20 2c 40 66 6f | 72 6d 73 29 0d 09 09 09 |ame ,@fo|rms)....|
|00002c30| 09 09 28 24 70 6f 70 2d | 73 70 65 63 69 61 6c 2d |..($pop-|special-|
|00002c40| 62 69 6e 64 69 6e 67 73 | 20 27 2c 2a 6c 61 6d 62 |bindings| ',*lamb|
|00002c50| 64 61 2d 73 70 65 63 69 | 61 6c 2d 76 61 72 73 2a |da-speci|al-vars*|
|00002c60| 29 29 29 0d 0d 09 09 09 | 3b 3b 20 65 6c 73 65 20 |))).....|;; else |
|00002c70| 65 78 65 63 75 74 65 20 | 74 68 65 20 66 6f 72 6d |execute |the form|
|00002c80| 73 20 64 69 72 65 63 74 | 6c 79 0d 09 09 09 3b 3b |s direct|ly....;;|
|00002c90| 20 63 6f 6d 70 69 6c 65 | 20 74 68 65 20 66 6f 72 | compile| the for|
|00002ca0| 6d 73 20 61 73 20 61 20 | 62 6c 6f 63 6b 0d 09 09 |ms as a |block...|
|00002cb0| 09 28 63 6f 6d 70 69 6c | 65 2d 62 6c 6f 63 6b 2d |.(compil|e-block-|
|00002cc0| 66 6f 72 6d 20 60 28 62 | 6c 6f 63 6b 20 2c 66 75 |form `(b|lock ,fu|
|00002cd0| 6e 63 2d 6e 61 6d 65 20 | 2c 40 66 6f 72 6d 73 29 |nc-name |,@forms)|
|00002ce0| 29 29 0d 0d 09 09 3b 3b | 20 65 6c 69 6d 69 6e 61 |))....;;| elimina|
|00002cf0| 74 65 20 74 61 69 6c 20 | 72 65 63 75 72 73 69 6f |te tail |recursio|
|00002d00| 6e 0d 09 09 28 69 66 20 | 2a 6c 61 73 74 2d 63 61 |n...(if |*last-ca|
|00002d10| 6c 6c 2d 77 61 73 2d 74 | 61 69 6c 2d 72 65 63 75 |ll-was-t|ail-recu|
|00002d20| 72 73 69 6f 6e 2a 0d 09 | 09 09 28 6c 65 74 2a 20 |rsion*..|..(let* |
|00002d30| 28 28 6e 75 6d 2d 63 61 | 6c 6c 2d 69 6e 73 74 72 |((num-ca|ll-instr|
|00002d40| 75 63 74 69 6f 6e 73 20 | 28 2d 20 28 6c 65 6e 67 |uctions |(- (leng|
|00002d50| 74 68 20 2a 61 73 6d 2a | 29 20 28 6c 65 6e 67 74 |th *asm*|) (lengt|
|00002d60| 68 20 2a 6c 61 73 74 2d | 63 61 6c 6c 2d 77 61 73 |h *last-|call-was|
|00002d70| 2d 74 61 69 6c 2d 72 65 | 63 75 72 73 69 6f 6e 2a |-tail-re|cursion*|
|00002d80| 29 29 29 0d 09 09 09 09 | 20 20 20 28 63 61 6c 6c |))).....| (call|
|00002d90| 2d 69 6e 73 74 72 75 63 | 74 69 6f 6e 73 20 28 72 |-instruc|tions (r|
|00002da0| 65 76 65 72 73 65 20 28 | 73 75 62 73 65 71 20 2a |everse (|subseq *|
|00002db0| 61 73 6d 2a 20 30 20 6e | 75 6d 2d 63 61 6c 6c 2d |asm* 0 n|um-call-|
|00002dc0| 69 6e 73 74 72 75 63 74 | 69 6f 6e 73 29 29 29 0d |instruct|ions))).|
|00002dd0| 09 09 09 09 20 20 20 28 | 66 69 6e 64 2d 74 6f 70 |.... (|find-top|
|00002de0| 2d 6c 61 62 65 6c 20 28 | 67 65 6e 73 79 6d 29 29 |-label (|gensym))|
|00002df0| 0d 09 09 09 09 20 20 20 | 28 63 6f 70 79 2d 6c 61 |..... |(copy-la|
|00002e00| 62 65 6c 29 29 0d 0d 09 | 09 09 09 3b 3b 20 73 74 |bel))...|...;; st|
|00002e10| 72 69 70 20 6f 66 66 20 | 74 68 65 20 66 75 6e 63 |rip off |the func|
|00002e20| 74 69 6f 6e 20 63 61 6c | 6c 0d 09 09 09 09 28 73 |tion cal|l.....(s|
|00002e30| 65 74 71 20 2a 61 73 6d | 2a 20 2a 6c 61 73 74 2d |etq *asm|* *last-|
|00002e40| 63 61 6c 6c 2d 77 61 73 | 2d 74 61 69 6c 2d 72 65 |call-was|-tail-re|
|00002e50| 63 75 72 73 69 6f 6e 2a | 29 0d 0d 09 09 09 09 3b |cursion*|)......;|
|00002e60| 3b 20 70 75 73 68 20 61 | 6c 6c 20 69 6e 73 74 72 |; push a|ll instr|
|00002e70| 75 63 74 69 6f 6e 73 20 | 75 70 20 74 6f 20 74 68 |uctions |up to th|
|00002e80| 65 20 62 73 72 0d 09 09 | 09 09 28 64 6f 20 28 28 |e bsr...|..(do ((|
|00002e90| 69 6e 73 74 20 28 70 6f | 70 20 63 61 6c 6c 2d 69 |inst (po|p call-i|
|00002ea0| 6e 73 74 72 75 63 74 69 | 6f 6e 73 29 20 28 70 6f |nstructi|ons) (po|
|00002eb0| 70 20 63 61 6c 6c 2d 69 | 6e 73 74 72 75 63 74 69 |p call-i|nstructi|
|00002ec0| 6f 6e 73 29 29 29 0d 09 | 09 09 09 09 28 28 6f 72 |ons)))..|....((or|
|00002ed0| 20 28 6e 75 6c 6c 20 63 | 61 6c 6c 2d 69 6e 73 74 | (null c|all-inst|
|00002ee0| 72 75 63 74 69 6f 6e 73 | 29 20 0d 09 09 09 09 09 |ructions|) ......|
|00002ef0| 09 28 61 6e 64 20 28 63 | 6f 6e 73 70 20 69 6e 73 |.(and (c|onsp ins|
|00002f00| 74 29 20 28 65 71 20 28 | 63 61 72 20 69 6e 73 74 |t) (eq (|car inst|
|00002f10| 29 20 27 61 73 73 65 6d | 62 6c 65 72 3a 3a 62 73 |) 'assem|bler::bs|
|00002f20| 72 29 29 29 29 0d 09 09 | 09 09 09 28 70 75 73 68 |r))))...|...(push|
|00002f30| 20 69 6e 73 74 20 2a 61 | 73 6d 2a 29 29 0d 0d 09 | inst *a|sm*))...|
|00002f40| 09 09 09 3b 3b 20 6d 6f | 76 65 20 70 61 73 73 65 |...;; mo|ve passe|
|00002f50| 64 20 70 61 72 61 6d 73 | 20 74 6f 20 6f 75 74 65 |d params| to oute|
|00002f60| 72 20 73 74 61 63 6b 20 | 66 72 61 6d 65 0d 09 09 |r stack |frame...|
|00002f70| 09 09 3b 3b 20 61 64 64 | 20 72 65 74 75 72 6e 20 |..;; add| return |
|00002f80| 61 64 64 72 65 73 73 20 | 61 6e 64 20 62 72 61 6e |address |and bran|
|00002f90| 63 68 20 69 6e 73 74 72 | 75 63 74 69 6f 6e 20 74 |ch instr|uction t|
|00002fa0| 6f 20 73 69 6d 75 6c 61 | 74 65 20 6a 73 72 0d 09 |o simula|te jsr..|
|00002fb0| 09 09 09 5b 0d 09 09 09 | 09 09 60 28 6d 6f 76 65 |...[....|..`(move|
|00002fc0| 2e 6c 20 61 37 20 61 33 | 29 0d 09 09 09 09 09 0d |.l a7 a3|).......|
|00002fd0| 09 09 09 09 09 3b 3b 20 | 70 6f 73 69 74 69 6f 6e |.....;; |position|
|00002fe0| 20 61 33 20 61 62 6f 76 | 65 20 74 6f 70 20 6f 66 | a3 abov|e top of|
|00002ff0| 20 70 61 72 61 6d 65 74 | 65 72 20 66 72 61 6d 65 | paramet|er frame|
|00003000| 0d 09 09 09 09 09 66 69 | 6e 64 2d 74 6f 70 2d 6c |......fi|nd-top-l|
|00003010| 61 62 65 6c 09 09 0d 09 | 09 09 09 09 60 28 74 73 |abel....|....`(ts|
|00003020| 74 2e 6c 20 28 61 33 2b | 29 29 0d 09 09 09 09 09 |t.l (a3+|))......|
|00003030| 60 28 62 6e 65 20 2c 66 | 69 6e 64 2d 74 6f 70 2d |`(bne ,f|ind-top-|
|00003040| 6c 61 62 65 6c 29 0d 0d | 09 09 09 09 09 3b 3b 20 |label)..|.....;; |
|00003050| 63 6f 70 79 20 70 61 72 | 61 6d 65 74 65 72 73 0d |copy par|ameters.|
|00003060| 09 09 09 09 09 63 6f 70 | 79 2d 6c 61 62 65 6c 0d |.....cop|y-label.|
|00003070| 09 09 09 09 09 60 28 6d | 6f 76 65 2e 6c 20 28 2d |.....`(m|ove.l (-|
|00003080| 61 33 29 20 28 2d 61 32 | 29 29 0d 09 09 09 09 09 |a3) (-a2|))......|
|00003090| 60 28 6d 6f 76 65 2e 6c | 20 61 33 20 64 30 29 09 |`(move.l| a3 d0).|
|000030a0| 09 09 3b 3b 20 68 61 76 | 65 6e 27 74 20 69 6d 70 |..;; hav|en't imp|
|000030b0| 6c 65 6d 65 6e 74 65 64 | 20 63 6d 70 61 2e 6c 20 |lemented| cmpa.l |
|000030c0| 69 6e 73 74 72 75 63 74 | 69 6f 6e 20 79 65 74 0d |instruct|ion yet.|
|000030d0| 09 09 09 09 09 60 28 63 | 6d 70 2e 6c 20 61 37 20 |.....`(c|mp.l a7 |
|000030e0| 64 30 29 0d 09 09 09 09 | 09 60 28 62 6e 65 20 2c |d0).....|.`(bne ,|
|000030f0| 63 6f 70 79 2d 6c 61 62 | 65 6c 29 0d 09 09 09 09 |copy-lab|el).....|
|00003100| 09 60 28 75 6e 6c 6b 20 | 61 36 29 0d 09 09 09 09 |.`(unlk |a6).....|
|00003110| 09 60 28 6d 6f 76 65 2e | 6c 20 28 61 37 29 20 61 |.`(move.|l (a7) a|
|00003120| 30 29 09 09 09 3b 20 67 | 65 74 20 72 65 74 75 72 |0)...; g|et retur|
|00003130| 6e 20 61 64 64 72 65 73 | 73 20 69 6e 20 61 30 0d |n addres|s in a0.|
|00003140| 09 09 09 09 09 60 28 6c | 65 61 20 28 61 32 20 34 |.....`(l|ea (a2 4|
|00003150| 29 20 61 37 29 0d 09 09 | 09 09 09 60 28 6d 6f 76 |) a7)...|...`(mov|
|00003160| 65 2e 6c 20 61 37 20 28 | 2d 61 37 29 29 0d 09 09 |e.l a7 (|-a7))...|
|00003170| 09 09 09 60 28 6d 6f 76 | 65 2e 6c 20 61 30 20 28 |...`(mov|e.l a0 (|
|00003180| 2d 61 37 29 29 0d 09 09 | 09 09 09 60 28 62 72 61 |-a7))...|...`(bra|
|00003190| 20 2c 2a 66 75 6e 63 74 | 69 6f 6e 2d 65 6e 74 72 | ,*funct|ion-entr|
|000031a0| 79 2d 6c 61 62 65 6c 2a | 29 0d 09 09 09 09 5d 0d |y-label*|).....].|
|000031b0| 09 09 09 09 0d 09 09 09 | 09 3b 3b 20 61 64 64 20 |........|.;; add |
|000031c0| 74 68 65 20 72 65 73 74 | 20 6f 66 20 74 68 65 20 |the rest| of the |
|000031d0| 69 6e 73 74 72 75 63 74 | 69 6f 6e 73 0d 09 09 09 |instruct|ions....|
|000031e0| 09 28 64 6f 20 28 28 69 | 6e 73 74 20 28 70 6f 70 |.(do ((i|nst (pop|
|000031f0| 20 63 61 6c 6c 2d 69 6e | 73 74 72 75 63 74 69 6f | call-in|structio|
|00003200| 6e 73 29 20 28 70 6f 70 | 20 63 61 6c 6c 2d 69 6e |ns) (pop| call-in|
|00003210| 73 74 72 75 63 74 69 6f | 6e 73 29 29 29 0d 09 09 |structio|ns)))...|
|00003220| 09 09 09 28 28 6e 75 6c | 6c 20 63 61 6c 6c 2d 69 |...((nul|l call-i|
|00003230| 6e 73 74 72 75 63 74 69 | 6f 6e 73 29 29 20 0d 09 |nstructi|ons)) ..|
|00003240| 09 09 09 09 28 70 75 73 | 68 20 69 6e 73 74 20 2a |....(pus|h inst *|
|00003250| 61 73 6d 2a 29 29 29 29 | 0d 09 09 09 09 0d 09 09 |asm*))))|........|
|00003260| 3b 3b 20 6d 61 6b 65 20 | 73 75 72 65 20 62 6f 67 |;; make |sure bog|
|00003270| 75 73 20 6d 75 6c 74 69 | 70 6c 65 20 76 61 6c 75 |us multi|ple valu|
|00003280| 65 73 20 64 6f 6e 27 74 | 20 67 65 74 20 72 65 74 |es don't| get ret|
|00003290| 75 72 6e 65 64 0d 09 09 | 28 75 6e 6c 65 73 73 20 |urned...|(unless |
|000032a0| 2a 6c 61 73 74 2d 63 61 | 6c 6c 2d 77 61 73 2d 76 |*last-ca|ll-was-v|
|000032b0| 61 6c 75 65 73 2a 20 28 | 6b 69 6c 6c 2d 6d 75 6c |alues* (|kill-mul|
|000032c0| 74 69 70 6c 65 2d 76 61 | 6c 75 65 73 29 29 0d 0d |tiple-va|lues))..|
|000032d0| 09 09 28 65 6d 69 74 2d | 65 70 69 6c 6f 67 29 0d |..(emit-|epilog).|
|000032e0| 09 09 28 70 6f 70 2d 63 | 6c 65 61 6e 75 70 29 09 |..(pop-c|leanup).|
|000032f0| 09 0d 09 09 28 69 66 20 | 2a 61 73 73 65 6d 62 6c |....(if |*assembl|
|00003300| 65 2d 63 6f 64 65 2a 20 | 0d 09 09 09 28 72 65 74 |e-code* |....(ret|
|00003310| 75 72 6e 20 28 61 73 73 | 65 6d 62 6c 65 20 2a 61 |urn (ass|emble *a|
|00003320| 73 6d 2a 20 2a 72 65 66 | 65 72 65 6e 63 65 73 2a |sm* *ref|erences*|
|00003330| 20 6e 69 6c 29 29 09 09 | 09 0d 09 09 09 28 72 65 | nil))..|.....(re|
|00003340| 74 75 72 6e 20 2a 61 73 | 6d 2a 29 29 29 29 0d 0d |turn *as|m*))))..|
|00003350| 0d 28 64 65 66 75 6e 20 | 63 6f 6d 70 69 6c 65 2d |.(defun |compile-|
|00003360| 6c 61 6d 62 64 61 2d 61 | 72 67 73 20 28 29 0d 09 |lambda-a|rgs ()..|
|00003370| 28 63 6f 6d 70 69 6c 65 | 2d 6c 61 6d 62 64 61 2d |(compile|-lambda-|
|00003380| 72 65 71 75 69 72 65 64 | 2d 61 72 67 73 29 0d 09 |required|-args)..|
|00003390| 28 63 6f 6d 70 69 6c 65 | 2d 6c 61 6d 62 64 61 2d |(compile|-lambda-|
|000033a0| 6f 70 74 69 6f 6e 61 6c | 2d 61 72 67 73 29 0d 09 |optional|-args)..|
|000033b0| 28 63 6f 6d 70 69 6c 65 | 2d 6c 61 6d 62 64 61 2d |(compile|-lambda-|
|000033c0| 72 65 73 74 2d 61 72 67 | 73 29 09 09 0d 09 28 63 |rest-arg|s)....(c|
|000033d0| 68 65 63 6b 2d 6e 6f 2d | 6d 6f 72 65 2d 61 72 67 |heck-no-|more-arg|
|000033e0| 73 29 0d 09 28 63 6f 6d | 70 69 6c 65 2d 6c 61 6d |s)..(com|pile-lam|
|000033f0| 62 64 61 2d 6b 65 79 2d | 61 72 67 73 29 29 0d 09 |bda-key-|args))..|
|00003400| 0d 0d 28 64 65 66 75 6e | 20 63 6f 6c 6c 65 63 74 |..(defun| collect|
|00003410| 2d 6e 65 77 2d 76 61 72 | 73 20 28 6c 61 6d 62 64 |-new-var|s (lambd|
|00003420| 61 2d 6c 69 73 74 29 0d | 09 28 6c 65 74 20 28 28 |a-list).|.(let ((|
|00003430| 6e 65 77 2d 76 61 72 73 | 20 6e 69 6c 29 28 73 75 |new-vars| nil)(su|
|00003440| 70 70 6c 69 65 64 5f 70 | 5f 76 61 72 73 20 6e 69 |pplied_p|_vars ni|
|00003450| 6c 29 29 0d 09 09 28 64 | 6f 6c 69 73 74 20 28 6e |l))...(d|olist (n|
|00003460| 20 6c 61 6d 62 64 61 2d | 6c 69 73 74 29 09 09 09 | lambda-|list)...|
|00003470| 09 09 3b 3b 20 61 64 64 | 20 6c 65 78 69 63 61 6c |..;; add| lexical|
|00003480| 20 76 61 72 73 0d 09 09 | 09 28 69 66 20 28 6e 6f | vars...|.(if (no|
|00003490| 74 20 28 6d 65 6d 62 65 | 72 20 6e 20 2a 6c 61 6d |t (membe|r n *lam|
|000034a0| 62 64 61 2d 6c 69 73 74 | 2d 6b 65 79 77 6f 72 64 |bda-list|-keyword|
|000034b0| 73 2a 29 29 0d 09 09 09 | 09 28 70 72 6f 67 6e 0d |s*))....|.(progn.|
|000034c0| 09 09 09 09 09 28 69 66 | 20 28 63 6f 6e 73 70 20 |.....(if| (consp |
|000034d0| 6e 29 0d 09 09 09 09 09 | 09 28 70 72 6f 67 6e 0d |n)......|.(progn.|
|000034e0| 09 09 09 09 09 09 09 28 | 69 66 20 28 3e 3d 20 28 |.......(|if (>= (|
|000034f0| 6c 65 6e 67 74 68 20 6e | 29 20 33 29 09 09 3b 3b |length n|) 3)..;;|
|00003500| 20 67 65 74 20 73 75 70 | 70 6c 69 65 64 5f 70 20 | get sup|plied_p |
|00003510| 73 79 6d 62 6f 6c 73 0d | 09 09 09 09 09 09 09 09 |symbols.|........|
|00003520| 28 70 75 73 68 20 28 63 | 61 64 64 72 20 6e 29 20 |(push (c|addr n) |
|00003530| 73 75 70 70 6c 69 65 64 | 5f 70 5f 76 61 72 73 29 |supplied|_p_vars)|
|00003540| 29 0d 09 09 09 09 09 09 | 09 28 70 75 73 68 20 28 |).......|.(push (|
|00003550| 63 6f 6e 73 20 28 63 61 | 72 20 6e 29 20 2a 6c 65 |cons (ca|r n) *le|
|00003560| 78 2d 63 6f 75 6e 74 65 | 72 2a 29 20 6e 65 77 2d |x-counte|r*) new-|
|00003570| 76 61 72 73 29 29 0d 09 | 09 09 09 09 09 28 70 75 |vars))..|.....(pu|
|00003580| 73 68 20 28 63 6f 6e 73 | 20 6e 20 2a 6c 65 78 2d |sh (cons| n *lex-|
|00003590| 63 6f 75 6e 74 65 72 2a | 29 20 6e 65 77 2d 76 61 |counter*|) new-va|
|000035a0| 72 73 29 29 0d 09 09 09 | 09 09 28 69 6e 63 66 20 |rs))....|..(incf |
|000035b0| 2a 6c 65 78 2d 63 6f 75 | 6e 74 65 72 2a 29 29 29 |*lex-cou|nter*)))|
|000035c0| 29 0d 09 09 28 64 6f 6c | 69 73 74 20 28 6e 20 73 |)...(dol|ist (n s|
|000035d0| 75 70 70 6c 69 65 64 5f | 70 5f 76 61 72 73 29 0d |upplied_|p_vars).|
|000035e0| 09 09 09 28 70 75 73 68 | 20 28 63 6f 6e 73 20 6e |...(push| (cons n|
|000035f0| 20 2a 6c 65 78 2d 63 6f | 75 6e 74 65 72 2a 29 20 | *lex-co|unter*) |
|00003600| 6e 65 77 2d 76 61 72 73 | 29 09 3b 3b 20 74 68 65 |new-vars|).;; the|
|00003610| 73 65 20 6e 65 65 64 20 | 74 6f 20 67 6f 20 6f 6e |se need |to go on|
|00003620| 20 74 68 65 20 65 6e 64 | 0d 09 09 09 28 69 6e 63 | the end|....(inc|
|00003630| 66 20 2a 6c 65 78 2d 63 | 6f 75 6e 74 65 72 2a 29 |f *lex-c|ounter*)|
|00003640| 29 0d 09 09 28 6e 72 65 | 76 65 72 73 65 20 6e 65 |)...(nre|verse ne|
|00003650| 77 2d 76 61 72 73 29 29 | 29 09 09 09 09 09 09 0d |w-vars))|).......|
|00003660| 0d 0d 3b 3b 20 65 6d 69 | 74 20 63 6f 64 65 20 66 |..;; emi|t code f|
|00003670| 6f 72 20 73 74 61 72 74 | 20 6f 66 20 66 75 6e 63 |or start| of func|
|00003680| 74 69 6f 6e 09 09 09 0d | 28 64 65 66 75 6e 20 65 |tion....|(defun e|
|00003690| 6d 69 74 2d 70 72 6f 6c | 6f 67 20 28 29 0d 09 5b |mit-prol|og ()..[|
|000036a0| 20 0d 09 09 60 28 6d 6f | 76 65 6d 2e 6c 09 61 30 | ...`(mo|vem.l.a0|
|000036b0| 20 61 32 20 61 33 20 61 | 34 20 64 33 20 28 2d 61 | a2 a3 a|4 d3 (-a|
|000036c0| 37 29 29 20 0d 09 5d 0d | 0d 09 28 69 66 20 28 6f |7)) ..].|..(if (o|
|000036d0| 72 20 2a 65 6d 62 65 64 | 64 65 64 2d 6c 61 6d 62 |r *embed|ded-lamb|
|000036e0| 64 61 73 2a 20 2a 65 6e | 76 69 72 6f 6e 6d 65 6e |das* *en|vironmen|
|000036f0| 74 2a 29 0d 09 5b 0d 09 | 09 60 28 62 73 72 20 32 |t*)..[..|.`(bsr 2|
|00003700| 29 09 09 09 09 09 09 3b | 20 70 75 73 68 20 63 75 |)......;| push cu|
|00003710| 72 72 65 6e 74 20 70 63 | 20 6f 6e 20 73 74 61 63 |rrent pc| on stac|
|00003720| 6b 0d 09 09 60 28 6d 6f | 76 65 2e 6c 20 28 61 37 |k...`(mo|ve.l (a7|
|00003730| 2b 29 20 61 34 29 09 09 | 09 09 3b 20 61 34 20 3d |+) a4)..|..; a4 =|
|00003740| 20 70 63 0d 09 09 60 28 | 6d 6f 76 65 2e 6c 20 28 | pc...`(|move.l (|
|00003750| 61 34 20 2d 31 36 29 20 | 61 34 29 09 09 09 3b 20 |a4 -16) |a4)...; |
|00003760| 61 34 20 3d 20 70 6f 69 | 6e 74 65 72 20 74 6f 20 |a4 = poi|nter to |
|00003770| 65 6e 76 69 72 6f 6e 6d | 65 6e 74 20 28 6a 75 73 |environm|ent (jus|
|00003780| 74 20 62 65 66 6f 72 65 | 20 63 6f 64 65 29 0d 09 |t before| code)..|
|00003790| 09 0d 09 5d 29 0d 09 0d | 09 5b 0d 09 09 60 28 6d |...])...|.[...`(m|
|000037a0| 6f 76 65 61 2e 6c 20 28 | 61 36 20 38 29 20 61 32 |ovea.l (|a6 8) a2|
|000037b0| 29 09 09 09 3b 20 61 32 | 20 3d 20 61 36 20 2b 20 |)...; a2| = a6 + |
|000037c0| 38 20 3d 20 70 61 72 61 | 6d 65 74 65 72 20 62 6c |8 = para|meter bl|
|000037d0| 6f 63 6b 0d 09 09 60 28 | 6c 65 61 20 28 61 37 20 |ock...`(|lea (a7 |
|000037e0| 32 30 29 20 61 33 29 09 | 09 09 09 3b 20 61 33 20 |20) a3).|...; a3 |
|000037f0| 3d 20 70 6f 69 6e 74 65 | 72 20 74 6f 20 6c 6f 63 |= pointe|r to loc|
|00003800| 61 6c 20 61 72 67 75 6d | 65 6e 74 73 0d 09 09 09 |al argum|ents....|
|00003810| 09 09 09 09 09 09 09 3b | 20 74 68 65 20 6f 66 66 |.......;| the off|
|00003820| 73 65 74 20 74 6f 20 61 | 37 20 73 68 6f 75 6c 64 |set to a|7 should|
|00003830| 20 62 65 20 34 20 2a 20 | 6e 75 6d 62 65 72 20 6f | be 4 * |number o|
|00003840| 66 0d 09 09 09 09 09 09 | 09 09 09 09 3b 20 72 65 |f.......|....; re|
|00003850| 67 69 73 74 65 72 73 20 | 73 61 76 65 64 21 0d 09 |gisters |saved!..|
|00003860| 5d 29 0d 0d 0d 3b 3b 20 | 65 6d 69 74 20 63 6f 64 |])...;; |emit cod|
|00003870| 65 20 66 6f 72 20 65 6e | 64 20 6f 66 20 66 75 6e |e for en|d of fun|
|00003880| 63 74 69 6f 6e 09 09 09 | 0d 28 64 65 66 75 6e 20 |ction...|.(defun |
|00003890| 65 6d 69 74 2d 65 70 69 | 6c 6f 67 20 28 29 0d 09 |emit-epi|log ()..|
|000038a0| 5b 0d 09 09 60 28 6d 6f | 76 65 2e 6c 20 64 33 20 |[...`(mo|ve.l d3 |
|000038b0| 64 30 29 0d 09 09 60 28 | 6d 6f 76 65 6d 2e 6c 20 |d0)...`(|movem.l |
|000038c0| 28 61 36 20 2c 28 2d 20 | 2d 32 30 20 28 2a 20 2a |(a6 ,(- |-20 (* *|
|000038d0| 6c 65 78 2d 63 6f 75 6e | 74 65 72 2a 20 34 29 29 |lex-coun|ter* 4))|
|000038e0| 29 20 61 30 20 61 32 20 | 61 33 20 61 34 20 64 33 |) a0 a2 |a3 a4 d3|
|000038f0| 29 0d 09 09 60 28 75 6e | 6c 6b 20 61 36 29 09 09 |)...`(un|lk a6)..|
|00003900| 09 09 09 09 3b 20 75 6e | 6c 69 6e 6b 20 66 72 61 |....; un|link fra|
|00003910| 6d 65 20 70 6f 69 6e 74 | 65 72 0d 09 09 60 28 72 |me point|er...`(r|
|00003920| 74 73 29 09 09 09 09 09 | 09 09 3b 20 64 30 20 61 |ts).....|..; d0 a|
|00003930| 6c 72 65 61 64 79 20 63 | 6f 6e 74 61 69 6e 73 20 |lready c|ontains |
|00003940| 72 65 74 75 72 6e 20 76 | 61 6c 75 65 0d 09 5d 0d |return v|alue..].|
|00003950| 09 0d 09 28 73 65 74 71 | 20 2a 61 73 6d 2a 20 28 |...(setq| *asm* (|
|00003960| 6e 72 65 76 65 72 73 65 | 20 2a 61 73 6d 2a 29 29 |nreverse| *asm*))|
|00003970| 0d 0d 09 3b 3b 20 54 68 | 65 73 65 20 6c 61 73 74 |...;; Th|ese last|
|00003980| 20 69 6e 73 74 72 75 63 | 74 69 6f 6e 73 20 67 65 | instruc|tions ge|
|00003990| 74 20 70 75 73 68 65 64 | 20 6f 6e 74 6f 20 74 68 |t pushed| onto th|
|000039a0| 65 20 62 65 67 69 6e 6e | 69 6e 67 0d 09 3b 3b 20 |e beginn|ing..;; |
|000039b0| 6f 66 20 74 68 65 20 28 | 6e 6f 77 2d 72 65 76 65 |of the (|now-reve|
|000039c0| 72 73 65 64 29 20 69 6e | 73 74 72 75 63 74 69 6f |rsed) in|structio|
|000039d0| 6e 73 2e 20 54 68 65 72 | 65 66 6f 72 65 20 74 68 |ns. Ther|efore th|
|000039e0| 65 79 20 61 72 65 20 72 | 65 76 65 72 73 65 64 0d |ey are r|eversed.|
|000039f0| 09 3b 3b 20 68 65 72 65 | 20 74 6f 20 63 6f 6d 65 |.;; here| to come|
|00003a00| 20 6f 75 74 20 69 6e 20 | 74 68 65 20 72 69 67 68 | out in |the righ|
|00003a10| 74 20 6f 72 64 65 72 2e | 0d 09 5b 0d 09 09 60 28 |t order.|..[...`(|
|00003a20| 6c 69 6e 6b 20 61 36 20 | 2c 28 2d 20 28 2a 20 2a |link a6 |,(- (* *|
|00003a30| 6c 65 78 2d 63 6f 75 6e | 74 65 72 2a 20 34 29 29 |lex-coun|ter* 4))|
|00003a40| 29 0d 09 09 2a 66 75 6e | 63 74 69 6f 6e 2d 65 6e |)...*fun|ction-en|
|00003a50| 74 72 79 2d 6c 61 62 65 | 6c 2a 0d 09 5d 09 0d 29 |try-labe|l*..]..)|
|00003a60| 0d 0d 0d 3b 3b 20 4d 61 | 6b 65 20 73 75 72 65 20 |...;; Ma|ke sure |
|00003a70| 74 68 65 72 65 20 61 72 | 65 20 6e 6f 20 6d 6f 72 |there ar|e no mor|
|00003a80| 65 20 61 72 67 75 6d 65 | 6e 74 73 2e 0d 28 64 65 |e argume|nts..(de|
|00003a90| 66 75 6e 20 63 68 65 63 | 6b 2d 6e 6f 2d 6d 6f 72 |fun chec|k-no-mor|
|00003aa0| 65 2d 61 72 67 73 20 28 | 29 0d 09 28 69 66 20 28 |e-args (|)..(if (|
|00003ab0| 6e 6f 74 20 28 6f 72 20 | 28 72 65 73 74 2d 61 72 |not (or |(rest-ar|
|00003ac0| 67 75 6d 65 6e 74 73 20 | 2a 6c 61 6d 62 64 61 2d |guments |*lambda-|
|00003ad0| 6c 69 73 74 2a 29 20 28 | 6b 65 79 2d 61 72 67 75 |list*) (|key-argu|
|00003ae0| 6d 65 6e 74 73 20 2a 6c | 61 6d 62 64 61 2d 6c 69 |ments *l|ambda-li|
|00003af0| 73 74 2a 29 29 29 0d 09 | 09 5b 0d 09 09 09 60 28 |st*)))..|.[....`(|
|00003b00| 6d 6f 76 65 2e 6c 20 28 | 61 32 2b 29 20 28 2d 61 |move.l (|a2+) (-a|
|00003b10| 37 29 29 09 09 09 09 3b | 20 67 65 74 20 61 72 67 |7))....;| get arg|
|00003b20| 75 6d 65 6e 74 0d 09 09 | 09 60 28 6a 73 72 20 23 |ument...|.`(jsr #|
|00003b30| 27 63 6f 6d 6d 6f 6e 2d | 6c 69 73 70 3a 3a 25 63 |'common-|lisp::%c|
|00003b40| 68 65 63 6b 4e 75 6c 6c | 29 20 09 3b 20 73 69 67 |heckNull|) .; sig|
|00003b50| 6e 61 6c 20 65 72 72 6f | 72 20 69 66 20 65 78 74 |nal erro|r if ext|
|00003b60| 72 61 20 61 72 67 75 6d | 65 6e 74 0d 09 09 09 60 |ra argum|ent....`|
|00003b70| 28 6c 65 61 20 28 61 37 | 20 34 29 20 61 37 29 20 |(lea (a7| 4) a7) |
|00003b80| 09 20 09 09 09 09 3b 20 | 63 6c 65 61 6e 75 70 20 |. ....; |cleanup |
|00003b90| 73 74 61 63 6b 0d 09 09 | 5d 29 29 0d 0d 3b 3b 0d |stack...|]))..;;.|
|00003ba0| 3b 3b 09 63 6f 6d 70 69 | 6c 65 2d 6c 61 6d 62 64 |;;.compi|le-lambd|
|00003bb0| 61 2d 72 65 71 75 69 72 | 65 64 2d 61 72 67 73 0d |a-requir|ed-args.|
|00003bc0| 3b 3b 09 47 65 6e 65 72 | 61 74 65 73 20 63 6f 64 |;;.Gener|ates cod|
|00003bd0| 65 20 74 6f 20 69 6e 69 | 74 69 61 6c 69 7a 65 20 |e to ini|tialize |
|00003be0| 72 65 71 75 69 72 65 64 | 20 61 72 67 75 6d 65 6e |required| argumen|
|00003bf0| 73 74 73 2e 0d 3b 3b 0d | 28 64 65 66 75 6e 20 63 |sts..;;.|(defun c|
|00003c00| 6f 6d 70 69 6c 65 2d 6c | 61 6d 62 64 61 2d 72 65 |ompile-l|ambda-re|
|00003c10| 71 75 69 72 65 64 2d 61 | 72 67 73 20 28 29 0d 09 |quired-a|rgs ()..|
|00003c20| 28 64 6f 6c 69 73 74 20 | 28 73 79 6d 20 28 72 65 |(dolist |(sym (re|
|00003c30| 71 75 69 72 65 64 2d 61 | 72 67 75 6d 65 6e 74 73 |quired-a|rguments|
|00003c40| 20 2a 6c 61 6d 62 64 61 | 2d 6c 69 73 74 2a 29 29 | *lambda|-list*))|
|00003c50| 0d 09 09 5b 0d 09 09 09 | 60 28 6d 6f 76 65 2e 6c |...[....|`(move.l|
|00003c60| 20 28 61 32 2b 29 20 28 | 2d 61 37 29 29 09 09 09 | (a2+) (|-a7))...|
|00003c70| 3b 20 67 65 74 20 61 72 | 67 75 6d 65 6e 74 0d 09 |; get ar|gument..|
|00003c80| 09 09 60 28 6a 73 72 20 | 23 27 63 6f 6d 6d 6f 6e |..`(jsr |#'common|
|00003c90| 2d 6c 69 73 70 3a 3a 25 | 63 68 65 63 6b 4f 62 6a |-lisp::%|checkObj|
|00003ca0| 29 20 3b 20 73 69 67 6e | 61 6c 20 65 72 72 6f 72 |) ; sign|al error|
|00003cb0| 20 69 66 20 61 72 67 75 | 6d 65 6e 74 20 6d 69 73 | if argu|ment mis|
|00003cc0| 73 69 6e 67 0d 09 09 09 | 60 28 6c 65 61 20 28 61 |sing....|`(lea (a|
|00003cd0| 37 20 34 29 20 61 37 29 | 20 09 20 09 09 09 3b 20 |7 4) a7)| . ...; |
|00003ce0| 63 6c 65 61 6e 75 70 20 | 73 74 61 63 6b 0d 09 09 |cleanup |stack...|
|00003cf0| 09 60 28 6d 6f 76 65 2e | 6c 20 64 30 20 28 61 33 |.`(move.|l d0 (a3|
|00003d00| 20 2c 28 2a 20 2a 61 72 | 67 2d 63 6f 75 6e 74 2a | ,(* *ar|g-count*|
|00003d10| 20 34 29 29 29 0d 09 09 | 5d 0d 09 09 0d 09 09 28 | 4)))...|]......(|
|00003d20| 69 66 20 28 6f 72 20 28 | 73 70 65 63 69 61 6c 2d |if (or (|special-|
|00003d30| 76 61 72 69 61 62 6c 65 | 2d 70 20 73 79 6d 29 20 |variable|-p sym) |
|00003d40| 28 6d 65 6d 62 65 72 20 | 73 79 6d 20 2a 6c 61 6d |(member |sym *lam|
|00003d50| 62 64 61 2d 73 70 65 63 | 69 61 6c 2d 64 65 63 73 |bda-spec|ial-decs|
|00003d60| 2a 29 29 0d 09 09 09 28 | 70 72 6f 67 6e 20 0d 09 |*))....(|progn ..|
|00003d70| 09 09 09 28 70 75 73 68 | 20 73 79 6d 20 2a 6c 61 |...(push| sym *la|
|00003d80| 6d 62 64 61 2d 73 70 65 | 63 69 61 6c 2d 76 61 72 |mbda-spe|cial-var|
|00003d90| 73 2a 29 0d 09 09 09 09 | 5b 0d 09 09 09 09 09 60 |s*).....|[......`|
|00003da0| 28 6d 6f 76 65 2e 6c 20 | 30 20 28 2d 61 37 29 29 |(move.l |0 (-a7))|
|00003db0| 0d 09 09 09 09 09 60 28 | 6d 6f 76 65 2e 6c 20 28 |......`(|move.l (|
|00003dc0| 61 33 20 2c 28 2a 20 2a | 61 72 67 2d 63 6f 75 6e |a3 ,(* *|arg-coun|
|00003dd0| 74 2a 20 34 29 29 20 28 | 2d 61 37 29 29 0d 09 09 |t* 4)) (|-a7))...|
|00003de0| 09 09 09 60 28 6d 6f 76 | 65 2e 6c 20 27 2c 73 79 |...`(mov|e.l ',sy|
|00003df0| 6d 20 28 2d 61 37 29 29 | 0d 09 09 09 09 09 60 28 |m (-a7))|......`(|
|00003e00| 6d 6f 76 65 2e 6c 20 61 | 37 20 28 2d 61 37 29 29 |move.l a|7 (-a7))|
|00003e10| 0d 09 09 09 09 09 60 28 | 6a 73 72 20 23 27 63 6f |......`(|jsr #'co|
|00003e20| 6d 6d 6f 6e 2d 6c 69 73 | 70 3a 3a 24 70 75 73 68 |mmon-lis|p::$push|
|00003e30| 2d 73 70 65 63 69 61 6c | 2d 62 69 6e 64 69 6e 67 |-special|-binding|
|00003e40| 73 29 0d 09 09 09 09 09 | 60 28 6c 65 61 20 28 61 |s)......|`(lea (a|
|00003e50| 37 20 31 36 29 20 61 37 | 29 0d 09 09 09 09 5d 29 |7 16) a7|).....])|
|00003e60| 29 0d 0d 09 09 28 69 6e | 63 66 20 2a 61 72 67 2d |)....(in|cf *arg-|
|00003e70| 63 6f 75 6e 74 2a 29 29 | 29 0d 0d 0d 3b 3b 0d 3b |count*))|)...;;.;|
|00003e80| 3b 09 63 6f 6d 70 69 6c | 65 2d 6c 61 6d 62 64 61 |;.compil|e-lambda|
|00003e90| 2d 6f 70 74 69 6f 6e 61 | 6c 2d 61 72 67 73 0d 3b |-optiona|l-args.;|
|00003ea0| 3b 09 47 65 6e 65 72 61 | 74 65 73 20 63 6f 64 65 |;.Genera|tes code|
|00003eb0| 20 74 6f 20 69 6e 69 74 | 69 61 6c 69 7a 65 20 6f | to init|ialize o|
|00003ec0| 70 74 69 6f 6e 61 6c 20 | 61 72 67 75 6d 65 6e 73 |ptional |argumens|
|00003ed0| 74 73 2e 0d 3b 3b 0d 28 | 64 65 66 75 6e 20 63 6f |ts..;;.(|defun co|
|00003ee0| 6d 70 69 6c 65 2d 6c 61 | 6d 62 64 61 2d 6f 70 74 |mpile-la|mbda-opt|
|00003ef0| 69 6f 6e 61 6c 2d 61 72 | 67 73 20 28 29 0d 09 28 |ional-ar|gs ()..(|
|00003f00| 64 6f 6c 69 73 74 20 28 | 73 79 6d 20 28 6f 70 74 |dolist (|sym (opt|
|00003f10| 69 6f 6e 61 6c 2d 61 72 | 67 75 6d 65 6e 74 73 20 |ional-ar|guments |
|00003f20| 2a 6c 61 6d 62 64 61 2d | 6c 69 73 74 2a 29 29 0d |*lambda-|list*)).|
|00003f30| 09 09 3b 3b 20 69 6e 69 | 74 69 61 6c 69 7a 65 20 |..;; ini|tialize |
|00003f40| 6f 70 74 69 6f 6e 61 6c | 20 76 61 72 69 61 62 6c |optional| variabl|
|00003f50| 65 0d 09 09 28 6c 65 74 | 20 28 28 65 6c 73 65 2d |e...(let| ((else-|
|00003f60| 6c 61 62 65 6c 20 28 67 | 65 6e 73 79 6d 29 29 20 |label (g|ensym)) |
|00003f70| 0d 09 09 20 20 09 20 20 | 28 65 6e 64 2d 6c 61 62 |... . |(end-lab|
|00003f80| 65 6c 20 28 67 65 6e 73 | 79 6d 29 29 29 0d 09 09 |el (gens|ym)))...|
|00003f90| 09 5b 0d 09 09 09 09 60 | 28 74 73 74 2e 6c 20 28 |.[.....`|(tst.l (|
|00003fa0| 61 32 29 29 09 09 09 09 | 3b 3b 20 69 73 20 74 68 |a2))....|;; is th|
|00003fb0| 65 72 65 20 61 6e 20 61 | 72 67 75 6d 65 6e 74 0d |ere an a|rgument.|
|00003fc0| 09 09 09 09 60 28 62 65 | 71 20 2c 65 6c 73 65 2d |....`(be|q ,else-|
|00003fd0| 6c 61 62 65 6c 29 0d 09 | 09 09 5d 0d 09 09 09 28 |label)..|..]....(|
|00003fe0| 69 66 20 28 61 6e 64 20 | 28 63 6f 6e 73 70 20 73 |if (and |(consp s|
|00003ff0| 79 6d 29 20 28 3e 3d 20 | 28 6c 65 6e 67 74 68 20 |ym) (>= |(length |
|00004000| 73 79 6d 29 20 33 29 29 | 0d 09 09 09 09 28 63 6f |sym) 3))|.....(co|
|00004010| 6d 70 69 6c 65 2d 66 6f | 72 6d 20 60 28 73 65 74 |mpile-fo|rm `(set|
|00004020| 71 20 2c 28 63 61 64 64 | 72 20 73 79 6d 29 20 74 |q ,(cadd|r sym) t|
|00004030| 29 29 29 09 3b 3b 20 73 | 65 74 20 73 75 70 70 6c |))).;; s|et suppl|
|00004040| 69 65 64 5f 70 0d 09 09 | 09 5b 20 0d 09 09 09 09 |ied_p...|.[ .....|
|00004050| 60 28 6d 6f 76 65 2e 6c | 20 28 61 32 2b 29 20 28 |`(move.l| (a2+) (|
|00004060| 61 33 20 2c 28 2a 20 2a | 61 72 67 2d 63 6f 75 6e |a3 ,(* *|arg-coun|
|00004070| 74 2a 20 34 29 29 29 0d | 09 09 09 09 60 28 62 72 |t* 4))).|....`(br|
|00004080| 61 20 2c 65 6e 64 2d 6c | 61 62 65 6c 29 0d 09 09 |a ,end-l|abel)...|
|00004090| 09 09 65 6c 73 65 2d 6c | 61 62 65 6c 0d 09 09 09 |..else-l|abel....|
|000040a0| 5d 0d 09 09 09 09 0d 09 | 09 09 3b 3b 20 65 6c 73 |].......|..;; els|
|000040b0| 65 20 64 6f 20 64 65 66 | 61 75 6c 74 20 69 6e 69 |e do def|ault ini|
|000040c0| 74 69 61 6c 69 7a 61 74 | 69 6f 6e 0d 0d 09 09 09 |tializat|ion.....|
|000040d0| 28 69 66 20 28 61 6e 64 | 20 28 63 6f 6e 73 70 20 |(if (and| (consp |
|000040e0| 73 79 6d 29 20 28 3e 3d | 20 28 6c 65 6e 67 74 68 |sym) (>=| (length|
|000040f0| 20 73 79 6d 29 20 33 29 | 29 0d 09 09 09 09 28 63 | sym) 3)|).....(c|
|00004100| 6f 6d 70 69 6c 65 2d 66 | 6f 72 6d 20 60 28 73 65 |ompile-f|orm `(se|
|00004110| 74 71 20 2c 28 63 61 64 | 64 72 20 73 79 6d 29 20 |tq ,(cad|dr sym) |
|00004120| 6e 69 6c 29 29 29 09 3b | 3b 20 73 65 74 20 73 75 |nil))).;|; set su|
|00004130| 70 70 6c 69 65 64 5f 70 | 0d 0d 09 09 09 28 69 66 |pplied_p|.....(if|
|00004140| 20 28 61 6e 64 20 28 63 | 6f 6e 73 70 20 73 79 6d | (and (c|onsp sym|
|00004150| 29 20 28 63 64 72 20 73 | 79 6d 29 29 0d 09 09 09 |) (cdr s|ym))....|
|00004160| 09 28 70 72 6f 67 6e 0d | 09 09 09 09 09 5b 0d 09 |.(progn.|.....[..|
|00004170| 09 09 09 09 09 60 28 6d | 6f 76 65 6d 2e 6c 09 61 |.....`(m|ovem.l.a|
|00004180| 32 20 61 33 20 64 30 20 | 28 2d 61 37 29 29 0d 09 |2 a3 d0 |(-a7))..|
|00004190| 09 09 09 09 5d 0d 09 09 | 09 09 09 28 63 6f 6d 70 |....]...|...(comp|
|000041a0| 69 6c 65 2d 66 6f 72 6d | 20 28 63 61 64 72 20 73 |ile-form| (cadr s|
|000041b0| 79 6d 29 29 0d 09 09 09 | 09 09 5b 0d 09 09 09 09 |ym))....|..[.....|
|000041c0| 09 09 60 28 6d 6f 76 65 | 6d 2e 6c 20 28 61 37 2b |..`(move|m.l (a7+|
|000041d0| 29 20 61 32 20 61 33 20 | 64 30 29 0d 09 09 09 09 |) a2 a3 |d0).....|
|000041e0| 09 09 60 28 6d 6f 76 65 | 2e 6c 20 64 33 20 28 61 |..`(move|.l d3 (a|
|000041f0| 33 20 2c 28 2a 20 2a 61 | 72 67 2d 63 6f 75 6e 74 |3 ,(* *a|rg-count|
|00004200| 2a 20 34 29 29 29 0d 09 | 09 09 09 09 5d 29 0d 09 |* 4)))..|....])..|
|00004210| 09 09 09 3b 3b 20 65 6c | 73 65 0d 09 09 09 09 5b |...;; el|se.....[|
|00004220| 0d 09 09 09 09 09 60 28 | 6d 6f 76 65 2e 6c 20 27 |......`(|move.l '|
|00004230| 6e 69 6c 20 28 61 33 20 | 2c 28 2a 20 2a 61 72 67 |nil (a3 |,(* *arg|
|00004240| 2d 63 6f 75 6e 74 2a 20 | 34 29 29 29 0d 09 09 09 |-count* |4)))....|
|00004250| 09 5d 29 0d 09 09 09 5b | 0d 09 09 09 09 65 6e 64 |.])....[|.....end|
|00004260| 2d 6c 61 62 65 6c 0d 09 | 09 09 5d 29 0d 0d 09 09 |-label..|..])....|
|00004270| 28 69 66 20 28 6f 72 20 | 28 73 70 65 63 69 61 6c |(if (or |(special|
|00004280| 2d 76 61 72 69 61 62 6c | 65 2d 70 20 73 79 6d 29 |-variabl|e-p sym)|
|00004290| 20 28 6d 65 6d 62 65 72 | 20 73 79 6d 20 2a 6c 61 | (member| sym *la|
|000042a0| 6d 62 64 61 2d 73 70 65 | 63 69 61 6c 2d 64 65 63 |mbda-spe|cial-dec|
|000042b0| 73 2a 29 29 0d 09 09 09 | 28 70 72 6f 67 6e 20 0d |s*))....|(progn .|
|000042c0| 09 09 09 09 28 70 75 73 | 68 20 73 79 6d 20 2a 6c |....(pus|h sym *l|
|000042d0| 61 6d 62 64 61 2d 73 70 | 65 63 69 61 6c 2d 76 61 |ambda-sp|ecial-va|
|000042e0| 72 73 2a 29 0d 09 09 09 | 09 5b 0d 09 09 09 09 09 |rs*)....|.[......|
|000042f0| 60 28 6d 6f 76 65 2e 6c | 20 30 20 28 2d 61 37 29 |`(move.l| 0 (-a7)|
|00004300| 29 0d 09 09 09 09 09 60 | 28 6d 6f 76 65 2e 6c 20 |)......`|(move.l |
|00004310| 28 61 33 20 2c 28 2a 20 | 2a 61 72 67 2d 63 6f 75 |(a3 ,(* |*arg-cou|
|00004320| 6e 74 2a 20 34 29 29 20 | 28 2d 61 37 29 29 0d 09 |nt* 4)) |(-a7))..|
|00004330| 09 09 09 09 60 28 6d 6f | 76 65 2e 6c 20 27 2c 73 |....`(mo|ve.l ',s|
|00004340| 79 6d 20 28 2d 61 37 29 | 29 0d 09 09 09 09 09 60 |ym (-a7)|)......`|
|00004350| 28 6d 6f 76 65 2e 6c 20 | 61 37 20 28 2d 61 37 29 |(move.l |a7 (-a7)|
|00004360| 29 0d 09 09 09 09 09 60 | 28 6a 73 72 20 23 27 63 |)......`|(jsr #'c|
|00004370| 6f 6d 6d 6f 6e 2d 6c 69 | 73 70 3a 3a 24 70 75 73 |ommon-li|sp::$pus|
|00004380| 68 2d 73 70 65 63 69 61 | 6c 2d 62 69 6e 64 69 6e |h-specia|l-bindin|
|00004390| 67 73 29 0d 09 09 09 09 | 09 60 28 6c 65 61 20 28 |gs).....|.`(lea (|
|000043a0| 61 37 20 31 36 29 20 61 | 37 29 0d 09 09 09 09 5d |a7 16) a|7).....]|
|000043b0| 29 29 0d 09 09 09 0d 09 | 09 28 69 6e 63 66 20 2a |))......|.(incf *|
|000043c0| 61 72 67 2d 63 6f 75 6e | 74 2a 29 29 29 0d 0d 0d |arg-coun|t*)))...|
|000043d0| 3b 3b 0d 3b 3b 09 63 6f | 6d 70 69 6c 65 2d 6c 61 |;;.;;.co|mpile-la|
|000043e0| 6d 62 64 61 2d 72 65 73 | 74 2d 61 72 67 73 0d 3b |mbda-res|t-args.;|
|000043f0| 3b 09 47 65 6e 65 72 61 | 74 65 73 20 63 6f 64 65 |;.Genera|tes code|
|00004400| 20 74 6f 20 69 6e 69 74 | 69 61 6c 69 7a 65 20 72 | to init|ialize r|
|00004410| 65 73 74 20 61 72 67 75 | 6d 65 6e 74 73 2e 0d 3b |est argu|ments..;|
|00004420| 3b 09 57 65 20 61 6c 6c | 6f 77 20 6d 6f 72 65 20 |;.We all|ow more |
|00004430| 74 68 61 6e 20 6f 6e 65 | 2e 0d 3b 3b 0d 28 64 65 |than one|..;;.(de|
|00004440| 66 75 6e 20 63 6f 6d 70 | 69 6c 65 2d 6c 61 6d 62 |fun comp|ile-lamb|
|00004450| 64 61 2d 72 65 73 74 2d | 61 72 67 73 20 28 29 0d |da-rest-|args ().|
|00004460| 09 28 6c 65 74 2a 20 28 | 28 72 65 73 74 2d 61 72 |.(let* (|(rest-ar|
|00004470| 67 73 20 28 72 65 73 74 | 2d 61 72 67 75 6d 65 6e |gs (rest|-argumen|
|00004480| 74 73 20 2a 6c 61 6d 62 | 64 61 2d 6c 69 73 74 2a |ts *lamb|da-list*|
|00004490| 29 29 29 0d 09 09 28 69 | 66 20 72 65 73 74 2d 61 |)))...(i|f rest-a|
|000044a0| 72 67 73 0d 09 09 09 5b | 0d 09 09 09 09 60 28 6d |rgs....[|.....`(m|
|000044b0| 6f 76 65 2e 6c 20 61 32 | 20 28 2d 61 37 29 29 0d |ove.l a2| (-a7)).|
|000044c0| 09 09 09 09 60 28 6a 73 | 72 20 23 27 6c 69 73 74 |....`(js|r #'list|
|000044d0| 29 0d 09 09 09 09 60 28 | 6c 65 61 20 28 61 37 20 |).....`(|lea (a7 |
|000044e0| 34 29 20 61 37 29 0d 09 | 09 09 5d 29 0d 09 09 28 |4) a7)..|..])...(|
|000044f0| 64 6f 6c 69 73 74 20 28 | 73 79 6d 20 72 65 73 74 |dolist (|sym rest|
|00004500| 2d 61 72 67 73 29 0d 09 | 09 09 5b 0d 09 09 09 09 |-args)..|..[.....|
|00004510| 60 28 6d 6f 76 65 2e 6c | 20 64 30 20 28 61 33 20 |`(move.l| d0 (a3 |
|00004520| 2c 28 2a 20 2a 61 72 67 | 2d 63 6f 75 6e 74 2a 20 |,(* *arg|-count* |
|00004530| 34 29 29 29 0d 09 09 09 | 5d 0d 09 09 0d 09 09 28 |4)))....|]......(|
|00004540| 69 66 20 28 6f 72 20 28 | 73 70 65 63 69 61 6c 2d |if (or (|special-|
|00004550| 76 61 72 69 61 62 6c 65 | 2d 70 20 73 79 6d 29 20 |variable|-p sym) |
|00004560| 28 6d 65 6d 62 65 72 20 | 73 79 6d 20 2a 6c 61 6d |(member |sym *lam|
|00004570| 62 64 61 2d 73 70 65 63 | 69 61 6c 2d 64 65 63 73 |bda-spec|ial-decs|
|00004580| 2a 29 29 0d 09 09 09 09 | 28 70 72 6f 67 6e 20 0d |*)).....|(progn .|
|00004590| 09 09 09 09 09 28 70 75 | 73 68 20 73 79 6d 20 2a |.....(pu|sh sym *|
|000045a0| 6c 61 6d 62 64 61 2d 73 | 70 65 63 69 61 6c 2d 76 |lambda-s|pecial-v|
|000045b0| 61 72 73 2a 29 0d 09 09 | 09 09 09 5b 0d 09 09 09 |ars*)...|...[....|
|000045c0| 09 09 09 60 28 6d 6f 76 | 65 2e 6c 20 30 20 28 2d |...`(mov|e.l 0 (-|
|000045d0| 61 37 29 29 0d 09 09 09 | 09 09 09 60 28 6d 6f 76 |a7))....|...`(mov|
|000045e0| 65 2e 6c 20 28 61 33 20 | 2c 28 2a 20 2a 61 72 67 |e.l (a3 |,(* *arg|
|000045f0| 2d 63 6f 75 6e 74 2a 20 | 34 29 29 20 28 2d 61 37 |-count* |4)) (-a7|
|00004600| 29 29 0d 09 09 09 09 09 | 09 60 28 6d 6f 76 65 2e |))......|.`(move.|
|00004610| 6c 20 27 2c 73 79 6d 20 | 28 2d 61 37 29 29 0d 09 |l ',sym |(-a7))..|
|00004620| 09 09 09 09 09 60 28 6d | 6f 76 65 2e 6c 20 61 37 |.....`(m|ove.l a7|
|00004630| 20 28 2d 61 37 29 29 0d | 09 09 09 09 09 09 60 28 | (-a7)).|......`(|
|00004640| 6a 73 72 20 23 27 63 6f | 6d 6d 6f 6e 2d 6c 69 73 |jsr #'co|mmon-lis|
|00004650| 70 3a 3a 24 70 75 73 68 | 2d 73 70 65 63 69 61 6c |p::$push|-special|
|00004660| 2d 62 69 6e 64 69 6e 67 | 73 29 0d 09 09 09 09 09 |-binding|s)......|
|00004670| 09 60 28 6c 65 61 20 28 | 61 37 20 31 36 29 20 61 |.`(lea (|a7 16) a|
|00004680| 37 29 0d 09 09 09 09 09 | 5d 29 29 0d 0d 09 09 09 |7)......|])).....|
|00004690| 28 69 6e 63 66 20 2a 61 | 72 67 2d 63 6f 75 6e 74 |(incf *a|rg-count|
|000046a0| 2a 29 29 29 29 0d 0d 0d | 3b 3b 0d 3b 3b 09 63 6f |*))))...|;;.;;.co|
|000046b0| 6d 70 69 6c 65 2d 6c 61 | 6d 62 64 61 2d 6b 65 79 |mpile-la|mbda-key|
|000046c0| 2d 61 72 67 73 0d 3b 3b | 09 47 65 6e 65 72 61 74 |-args.;;|.Generat|
|000046d0| 65 73 20 63 6f 64 65 20 | 74 6f 20 69 6e 69 74 69 |es code |to initi|
|000046e0| 61 6c 69 7a 65 20 6b 65 | 79 20 61 72 67 75 6d 65 |alize ke|y argume|
|000046f0| 6e 73 74 73 2e 0d 3b 3b | 0d 28 64 65 66 75 6e 20 |nsts..;;|.(defun |
|00004700| 63 6f 6d 70 69 6c 65 2d | 6c 61 6d 62 64 61 2d 6b |compile-|lambda-k|
|00004710| 65 79 2d 61 72 67 73 20 | 28 29 0d 09 28 64 6f 6c |ey-args |()..(dol|
|00004720| 69 73 74 20 28 6e 20 28 | 6b 65 79 2d 61 72 67 75 |ist (n (|key-argu|
|00004730| 6d 65 6e 74 73 20 2a 6c | 61 6d 62 64 61 2d 6c 69 |ments *l|ambda-li|
|00004740| 73 74 2a 29 29 0d 09 09 | 28 6c 65 74 2a 20 28 28 |st*))...|(let* ((|
|00004750| 6c 6f 6f 70 2d 6c 61 62 | 65 6c 20 28 67 65 6e 73 |loop-lab|el (gens|
|00004760| 79 6d 29 29 0d 09 09 09 | 20 20 20 28 65 78 69 74 |ym))....| (exit|
|00004770| 2d 6c 61 62 65 6c 20 28 | 67 65 6e 73 79 6d 29 29 |-label (|gensym))|
|00004780| 0d 09 09 09 20 20 20 28 | 6e 6f 74 2d 66 6f 75 6e |.... (|not-foun|
|00004790| 64 2d 6c 61 62 65 6c 20 | 28 67 65 6e 73 79 6d 29 |d-label |(gensym)|
|000047a0| 29 0d 09 09 09 20 20 20 | 6c 65 78 2d 76 61 72 20 |).... |lex-var |
|000047b0| 0d 09 09 09 20 20 20 64 | 65 66 61 75 6c 74 2d 69 |.... d|efault-i|
|000047c0| 6e 69 74 20 0d 09 09 09 | 20 20 20 6b 65 79 2d 73 |nit ....| key-s|
|000047d0| 79 6d 62 6f 6c 29 0d 09 | 09 09 09 09 09 0d 09 09 |ymbol)..|........|
|000047e0| 09 28 69 66 20 28 63 6f | 6e 73 70 20 6e 29 0d 09 |.(if (co|nsp n)..|
|000047f0| 09 09 09 28 73 65 74 71 | 20 6c 65 78 2d 76 61 72 |...(setq| lex-var|
|00004800| 20 28 63 61 72 20 6e 29 | 29 0d 09 09 09 09 28 73 | (car n)|).....(s|
|00004810| 65 74 71 20 6c 65 78 2d | 76 61 72 20 6e 29 29 0d |etq lex-|var n)).|
|00004820| 09 09 09 09 09 09 09 0d | 09 09 09 28 69 66 20 28 |........|...(if (|
|00004830| 61 6e 64 20 28 63 6f 6e | 73 70 20 6e 29 20 28 63 |and (con|sp n) (c|
|00004840| 64 72 20 6e 29 29 0d 09 | 09 09 09 28 73 65 74 71 |dr n))..|...(setq|
|00004850| 20 64 65 66 61 75 6c 74 | 2d 69 6e 69 74 20 28 63 | default|-init (c|
|00004860| 61 64 72 20 6e 29 29 0d | 09 09 09 09 28 73 65 74 |adr n)).|....(set|
|00004870| 71 20 64 65 66 61 75 6c | 74 2d 69 6e 69 74 20 6e |q defaul|t-init n|
|00004880| 69 6c 29 29 09 09 09 09 | 09 09 0d 09 09 09 09 09 |il))....|........|
|00004890| 0d 09 09 09 28 73 65 74 | 71 20 6b 65 79 2d 73 79 |....(set|q key-sy|
|000048a0| 6d 62 6f 6c 20 0d 09 09 | 09 09 28 69 6e 74 65 72 |mbol ...|..(inter|
|000048b0| 6e 20 28 73 79 6d 62 6f | 6c 2d 6e 61 6d 65 20 6c |n (symbo|l-name l|
|000048c0| 65 78 2d 76 61 72 29 20 | 28 66 69 6e 64 2d 70 61 |ex-var) |(find-pa|
|000048d0| 63 6b 61 67 65 20 3a 6b | 65 79 77 6f 72 64 29 29 |ckage :k|eyword))|
|000048e0| 29 0d 09 09 09 09 09 09 | 0d 09 09 09 5b 0d 09 09 |).......|....[...|
|000048f0| 09 09 60 28 6d 6f 76 65 | 2e 6c 20 61 32 20 61 30 |..`(move|.l a2 a0|
|00004900| 29 09 09 09 3b 20 61 30 | 20 3d 20 63 75 72 72 65 |)...; a0| = curre|
|00004910| 6e 74 20 61 72 67 75 6d | 65 6e 74 20 6c 6f 63 61 |nt argum|ent loca|
|00004920| 74 69 6f 6e 0d 09 09 09 | 09 60 28 6d 6f 76 65 2e |tion....|.`(move.|
|00004930| 6c 20 27 2c 6b 65 79 2d | 73 79 6d 62 6f 6c 20 64 |l ',key-|symbol d|
|00004940| 30 29 0d 09 09 09 09 6c | 6f 6f 70 2d 6c 61 62 65 |0).....l|oop-labe|
|00004950| 6c 0d 09 09 09 09 60 28 | 74 73 74 2e 6c 20 28 61 |l.....`(|tst.l (a|
|00004960| 30 29 29 09 09 09 3b 20 | 6d 61 6b 65 20 73 75 72 |0))...; |make sur|
|00004970| 65 20 74 68 65 72 65 20 | 61 72 65 20 6d 6f 72 65 |e there |are more|
|00004980| 20 61 72 67 75 6d 65 6e | 74 73 0d 09 09 09 09 60 | argumen|ts.....`|
|00004990| 28 62 65 71 20 2c 6e 6f | 74 2d 66 6f 75 6e 64 2d |(beq ,no|t-found-|
|000049a0| 6c 61 62 65 6c 29 0d 09 | 09 09 09 60 28 63 6d 70 |label)..|...`(cmp|
|000049b0| 2e 6c 20 28 61 30 2b 29 | 20 64 30 29 0d 09 09 09 |.l (a0+)| d0)....|
|000049c0| 09 60 28 62 6e 65 20 2c | 6c 6f 6f 70 2d 6c 61 62 |.`(bne ,|loop-lab|
|000049d0| 65 6c 29 0d 09 09 09 09 | 60 28 6d 6f 76 65 2e 6c |el).....|`(move.l|
|000049e0| 20 28 61 30 29 20 28 2d | 61 37 29 29 09 3b 20 6d | (a0) (-|a7)).; m|
|000049f0| 61 6b 65 20 73 75 72 65 | 20 74 68 65 72 65 20 69 |ake sure| there i|
|00004a00| 73 20 61 6e 6f 74 68 65 | 72 20 61 72 67 75 6d 65 |s anothe|r argume|
|00004a10| 6e 74 0d 09 09 09 09 60 | 28 6a 73 72 20 23 27 63 |nt.....`|(jsr #'c|
|00004a20| 6f 6d 6d 6f 6e 2d 6c 69 | 73 70 3a 3a 25 63 68 65 |ommon-li|sp::%che|
|00004a30| 63 6b 4f 62 6a 29 0d 09 | 09 09 09 60 28 6c 65 61 |ckObj)..|...`(lea|
|00004a40| 20 28 61 37 20 34 29 20 | 61 37 29 20 09 20 09 3b | (a7 4) |a7) . .;|
|00004a50| 20 63 6c 65 61 6e 75 70 | 20 73 74 61 63 6b 0d 09 | cleanup| stack..|
|00004a60| 09 09 09 60 28 6d 6f 76 | 65 2e 6c 20 64 30 20 28 |...`(mov|e.l d0 (|
|00004a70| 61 33 20 2c 28 2a 20 2a | 61 72 67 2d 63 6f 75 6e |a3 ,(* *|arg-coun|
|00004a80| 74 2a 20 34 29 29 29 0d | 09 09 09 09 60 28 62 72 |t* 4))).|....`(br|
|00004a90| 61 20 2c 65 78 69 74 2d | 6c 61 62 65 6c 29 0d 09 |a ,exit-|label)..|
|00004aa0| 09 09 09 6e 6f 74 2d 66 | 6f 75 6e 64 2d 6c 61 62 |...not-f|ound-lab|
|00004ab0| 65 6c 09 0d 09 09 09 5d | 0d 09 09 09 28 63 6f 6d |el.....]|....(com|
|00004ac0| 70 69 6c 65 2d 66 6f 72 | 6d 20 64 65 66 61 75 6c |pile-for|m defaul|
|00004ad0| 74 2d 69 6e 69 74 29 0d | 09 09 09 5b 0d 09 09 09 |t-init).|...[....|
|00004ae0| 09 60 28 6d 6f 76 65 2e | 6c 20 64 33 20 28 61 33 |.`(move.|l d3 (a3|
|00004af0| 20 2c 28 2a 20 2a 61 72 | 67 2d 63 6f 75 6e 74 2a | ,(* *ar|g-count*|
|00004b00| 20 34 29 29 29 0d 09 09 | 09 09 65 78 69 74 2d 6c | 4)))...|..exit-l|
|00004b10| 61 62 65 6c 0d 09 09 09 | 5d 0d 0d 09 09 28 69 66 |abel....|]....(if|
|00004b20| 20 28 6f 72 20 28 73 70 | 65 63 69 61 6c 2d 76 61 | (or (sp|ecial-va|
|00004b30| 72 69 61 62 6c 65 2d 70 | 20 6e 29 20 28 6d 65 6d |riable-p| n) (mem|
|00004b40| 62 65 72 20 6e 20 2a 6c | 61 6d 62 64 61 2d 73 70 |ber n *l|ambda-sp|
|00004b50| 65 63 69 61 6c 2d 64 65 | 63 73 2a 29 29 0d 09 09 |ecial-de|cs*))...|
|00004b60| 09 09 28 70 72 6f 67 6e | 20 0d 09 09 09 09 09 28 |..(progn| ......(|
|00004b70| 70 75 73 68 20 6e 20 2a | 6c 61 6d 62 64 61 2d 73 |push n *|lambda-s|
|00004b80| 70 65 63 69 61 6c 2d 76 | 61 72 73 2a 29 0d 09 09 |pecial-v|ars*)...|
|00004b90| 09 09 09 5b 0d 09 09 09 | 09 09 09 60 28 6d 6f 76 |...[....|...`(mov|
|00004ba0| 65 2e 6c 20 30 20 28 2d | 61 37 29 29 0d 09 09 09 |e.l 0 (-|a7))....|
|00004bb0| 09 09 09 60 28 6d 6f 76 | 65 2e 6c 20 28 61 33 20 |...`(mov|e.l (a3 |
|00004bc0| 2c 28 2a 20 2a 61 72 67 | 2d 63 6f 75 6e 74 2a 20 |,(* *arg|-count* |
|00004bd0| 34 29 29 20 28 2d 61 37 | 29 29 0d 09 09 09 09 09 |4)) (-a7|))......|
|00004be0| 09 60 28 6d 6f 76 65 2e | 6c 20 27 2c 6e 20 28 2d |.`(move.|l ',n (-|
|00004bf0| 61 37 29 29 0d 09 09 09 | 09 09 09 60 28 6d 6f 76 |a7))....|...`(mov|
|00004c00| 65 2e 6c 20 61 37 20 28 | 2d 61 37 29 29 0d 09 09 |e.l a7 (|-a7))...|
|00004c10| 09 09 09 09 60 28 6a 73 | 72 20 23 27 63 6f 6d 6d |....`(js|r #'comm|
|00004c20| 6f 6e 2d 6c 69 73 70 3a | 3a 24 70 75 73 68 2d 73 |on-lisp:|:$push-s|
|00004c30| 70 65 63 69 61 6c 2d 62 | 69 6e 64 69 6e 67 73 29 |pecial-b|indings)|
|00004c40| 0d 09 09 09 09 09 09 60 | 28 6c 65 61 20 28 61 37 |.......`|(lea (a7|
|00004c50| 20 31 36 29 20 61 37 29 | 0d 09 09 09 09 09 5d 29 | 16) a7)|......])|
|00004c60| 29 0d 0d 09 09 09 28 69 | 6e 63 66 20 2a 61 72 67 |).....(i|ncf *arg|
|00004c70| 2d 63 6f 75 6e 74 2a 29 | 29 29 29 0d 0d 0d 3b 3b |-count*)|)))...;;|
|00004c80| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004c90| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004ca0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004cb0| 2d 2d 2d 0d 0d 28 64 65 | 66 75 6e 20 63 6f 6d 70 |---..(de|fun comp|
|00004cc0| 69 6c 65 2d 66 6f 72 6d | 20 28 66 6f 72 6d 29 0d |ile-form| (form).|
|00004cd0| 09 28 73 65 74 71 20 2a | 6c 61 73 74 2d 63 61 6c |.(setq *|last-cal|
|00004ce0| 6c 2d 77 61 73 2d 76 61 | 6c 75 65 73 2a 20 6e 69 |l-was-va|lues* ni|
|00004cf0| 6c 29 0d 09 28 73 65 74 | 71 20 2a 6c 61 73 74 2d |l)..(set|q *last-|
|00004d00| 63 61 6c 6c 2d 77 61 73 | 2d 74 61 69 6c 2d 72 65 |call-was|-tail-re|
|00004d10| 63 75 72 73 69 6f 6e 2a | 20 6e 69 6c 29 0d 09 28 |cursion*| nil)..(|
|00004d20| 63 6f 6e 64 20 0d 09 09 | 28 28 6e 75 6c 6c 20 66 |cond ...|((null f|
|00004d30| 6f 72 6d 29 20 28 63 6f | 6d 70 69 6c 65 2d 6e 69 |orm) (co|mpile-ni|
|00004d40| 6c 29 29 0d 09 09 28 28 | 73 79 6d 62 6f 6c 70 20 |l))...((|symbolp |
|00004d50| 66 6f 72 6d 29 20 28 63 | 6f 6d 70 69 6c 65 2d 73 |form) (c|ompile-s|
|00004d60| 79 6d 62 6f 6c 20 66 6f | 72 6d 29 29 0d 09 09 28 |ymbol fo|rm))...(|
|00004d70| 28 6e 6f 74 20 28 63 6f | 6e 73 70 20 66 6f 72 6d |(not (co|nsp form|
|00004d80| 29 29 09 28 63 6f 6d 70 | 69 6c 65 2d 6c 69 74 65 |)).(comp|ile-lite|
|00004d90| 72 61 6c 2d 66 6f 72 6d | 20 66 6f 72 6d 29 29 0d |ral-form| form)).|
|00004da0| 09 09 28 74 20 28 63 6f | 6d 70 69 6c 65 2d 6c 69 |..(t (co|mpile-li|
|00004db0| 73 74 2d 66 6f 72 6d 20 | 66 6f 72 6d 29 29 29 29 |st-form |form))))|
|00004dc0| 0d 0d 0d 28 64 65 66 75 | 6e 20 63 6f 6d 70 69 6c |...(defu|n compil|
|00004dd0| 65 2d 6c 69 73 74 2d 66 | 6f 72 6d 20 28 66 6f 72 |e-list-f|orm (for|
|00004de0| 6d 29 0d 09 28 6c 65 74 | 20 28 28 66 69 72 73 74 |m)..(let| ((first|
|00004df0| 6f 62 6a 20 28 63 61 72 | 20 66 6f 72 6d 29 29 29 |obj (car| form)))|
|00004e00| 0d 09 09 28 63 6f 6e 64 | 20 0d 09 09 09 28 28 63 |...(cond| ....((c|
|00004e10| 6f 6e 73 70 20 66 69 72 | 73 74 6f 62 6a 29 20 28 |onsp fir|stobj) (|
|00004e20| 63 6f 6d 70 69 6c 65 2d | 65 78 70 6c 69 63 69 74 |compile-|explicit|
|00004e30| 2d 6c 61 6d 62 64 61 20 | 66 6f 72 6d 29 29 0d 09 |-lambda |form))..|
|00004e40| 09 09 28 28 6e 6f 74 20 | 28 73 79 6d 62 6f 6c 70 |..((not |(symbolp|
|00004e50| 20 66 69 72 73 74 6f 62 | 6a 29 29 0d 09 09 09 09 | firstob|j)).....|
|00004e60| 28 65 72 72 6f 72 20 22 | 43 61 6e 27 74 20 63 6f |(error "|Can't co|
|00004e70| 6d 70 69 6c 65 20 66 6f | 72 6d 2d 2d 64 6f 65 73 |mpile fo|rm--does|
|00004e80| 20 6e 6f 74 20 62 65 67 | 69 6e 20 77 69 74 68 20 | not beg|in with |
|00004e90| 61 20 73 79 6d 62 6f 6c | 22 29 29 0d 09 09 09 28 |a symbol|"))....(|
|00004ea0| 28 6d 61 63 72 6f 2d 66 | 75 6e 63 74 69 6f 6e 20 |(macro-f|unction |
|00004eb0| 66 69 72 73 74 6f 62 6a | 29 20 28 63 6f 6d 70 69 |firstobj|) (compi|
|00004ec0| 6c 65 2d 66 6f 72 6d 20 | 28 6d 61 63 72 6f 65 78 |le-form |(macroex|
|00004ed0| 70 61 6e 64 20 66 6f 72 | 6d 29 29 29 0d 09 09 09 |pand for|m)))....|
|00004ee0| 28 28 73 70 65 63 69 61 | 6c 2d 66 6f 72 6d 2d 70 |((specia|l-form-p|
|00004ef0| 20 66 69 72 73 74 6f 62 | 6a 29 20 28 63 6f 6d 70 | firstob|j) (comp|
|00004f00| 69 6c 65 2d 73 70 65 63 | 69 61 6c 2d 66 6f 72 6d |ile-spec|ial-form|
|00004f10| 20 66 6f 72 6d 29 29 0d | 09 09 09 28 28 65 71 20 | form)).|...((eq |
|00004f20| 66 69 72 73 74 6f 62 6a | 20 27 63 6f 6d 6d 6f 6e |firstobj| 'common|
|00004f30| 2d 6c 69 73 70 3a 3a 76 | 61 6c 75 65 73 29 20 28 |-lisp::v|alues) (|
|00004f40| 63 6f 6d 70 69 6c 65 2d | 76 61 6c 75 65 73 2d 66 |compile-|values-f|
|00004f50| 6f 72 6d 20 66 6f 72 6d | 29 29 0d 09 09 09 28 74 |orm form|))....(t|
|00004f60| 20 28 63 6f 6d 70 69 6c | 65 2d 66 75 6e 63 74 69 | (compil|e-functi|
|00004f70| 6f 6e 2d 63 61 6c 6c 2d | 66 6f 72 6d 20 66 6f 72 |on-call-|form for|
|00004f80| 6d 29 29 29 29 29 0d 0d | 0d 28 64 65 66 75 6e 20 |m)))))..|.(defun |
|00004f90| 63 6f 6d 70 69 6c 65 2d | 73 70 65 63 69 61 6c 2d |compile-|special-|
|00004fa0| 66 6f 72 6d 20 28 66 6f | 72 6d 29 0d 09 28 63 61 |form (fo|rm)..(ca|
|00004fb0| 73 65 20 28 63 61 72 20 | 66 6f 72 6d 29 0d 09 09 |se (car |form)...|
|00004fc0| 28 71 75 6f 74 65 20 09 | 09 09 09 09 28 63 6f 6d |(quote .|....(com|
|00004fd0| 70 69 6c 65 2d 71 75 6f | 74 65 2d 66 6f 72 6d 20 |pile-quo|te-form |
|00004fe0| 66 6f 72 6d 29 29 20 0d | 09 09 28 69 66 20 09 09 |form)) .|..(if ..|
|00004ff0| 09 09 09 28 63 6f 6d 70 | 69 6c 65 2d 69 66 2d 66 |...(comp|ile-if-f|
|00005000| 6f 72 6d 20 66 6f 72 6d | 29 29 0d 09 09 28 74 61 |orm form|))...(ta|
|00005010| 67 62 6f 64 79 20 09 09 | 09 09 28 63 6f 6d 70 69 |gbody ..|..(compi|
|00005020| 6c 65 2d 74 61 67 62 6f | 64 79 2d 66 6f 72 6d 20 |le-tagbo|dy-form |
|00005030| 66 6f 72 6d 29 29 0d 09 | 09 28 67 6f 20 09 09 09 |form))..|.(go ...|
|00005040| 09 09 28 63 6f 6d 70 69 | 6c 65 2d 67 6f 2d 74 61 |..(compi|le-go-ta|
|00005050| 67 20 66 6f 72 6d 29 29 | 0d 09 09 28 73 65 74 71 |g form))|...(setq|
|00005060| 20 09 09 09 09 09 28 63 | 6f 6d 70 69 6c 65 2d 73 | .....(c|ompile-s|
|00005070| 65 74 71 2d 66 6f 72 6d | 20 66 6f 72 6d 29 29 0d |etq-form| form)).|
|00005080| 09 09 28 62 6c 6f 63 6b | 20 09 09 09 09 09 28 63 |..(block| .....(c|
|00005090| 6f 6d 70 69 6c 65 2d 62 | 6c 6f 63 6b 2d 66 6f 72 |ompile-b|lock-for|
|000050a0| 6d 20 66 6f 72 6d 29 29 | 0d 09 09 28 72 65 74 75 |m form))|...(retu|
|000050b0| 72 6e 2d 66 72 6f 6d 20 | 09 09 09 28 63 6f 6d 70 |rn-from |...(comp|
|000050c0| 69 6c 65 2d 72 65 74 75 | 72 6e 2d 66 72 6f 6d 2d |ile-retu|rn-from-|
|000050d0| 66 6f 72 6d 20 66 6f 72 | 6d 29 29 0d 09 09 28 70 |form for|m))...(p|
|000050e0| 72 6f 67 6e 20 09 09 09 | 09 09 28 63 6f 6d 70 69 |rogn ...|..(compi|
|000050f0| 6c 65 2d 70 72 6f 67 6e | 2d 66 6f 72 6d 20 66 6f |le-progn|-form fo|
|00005100| 72 6d 29 29 0d 09 09 28 | 6c 65 74 20 09 09 09 09 |rm))...(|let ....|
|00005110| 09 28 63 6f 6d 70 69 6c | 65 2d 6c 65 74 2d 66 6f |.(compil|e-let-fo|
|00005120| 72 6d 20 66 6f 72 6d 29 | 29 0d 09 09 28 6c 65 74 |rm form)|)...(let|
|00005130| 2a 20 09 09 09 09 09 28 | 63 6f 6d 70 69 6c 65 2d |* .....(|compile-|
|00005140| 6c 65 74 2a 2d 66 6f 72 | 6d 20 66 6f 72 6d 29 29 |let*-for|m form))|
|00005150| 0d 09 09 28 66 6c 65 74 | 20 09 09 09 09 09 28 63 |...(flet| .....(c|
|00005160| 6f 6d 70 69 6c 65 2d 66 | 6c 65 74 2d 66 6f 72 6d |ompile-f|let-form|
|00005170| 20 66 6f 72 6d 29 29 0d | 09 09 28 6c 61 62 65 6c | form)).|..(label|
|00005180| 73 20 09 09 09 09 28 63 | 6f 6d 70 69 6c 65 2d 6c |s ....(c|ompile-l|
|00005190| 61 62 65 6c 73 2d 66 6f | 72 6d 20 66 6f 72 6d 29 |abels-fo|rm form)|
|000051a0| 29 0d 09 09 28 66 75 6e | 63 74 69 6f 6e 09 09 09 |)...(fun|ction...|
|000051b0| 09 28 63 6f 6d 70 69 6c | 65 2d 66 75 6e 63 74 69 |.(compil|e-functi|
|000051c0| 6f 6e 2d 73 70 65 63 69 | 61 6c 2d 66 6f 72 6d 20 |on-speci|al-form |
|000051d0| 66 6f 72 6d 29 29 0d 09 | 09 28 63 61 74 63 68 09 |form))..|.(catch.|
|000051e0| 09 09 09 09 28 63 6f 6d | 70 69 6c 65 2d 63 61 74 |....(com|pile-cat|
|000051f0| 63 68 2d 66 6f 72 6d 20 | 66 6f 72 6d 29 29 0d 09 |ch-form |form))..|
|00005200| 09 28 74 68 72 6f 77 09 | 09 09 09 09 28 63 6f 6d |.(throw.|....(com|
|00005210| 70 69 6c 65 2d 74 68 72 | 6f 77 2d 66 6f 72 6d 20 |pile-thr|ow-form |
|00005220| 66 6f 72 6d 29 29 0d 09 | 09 28 75 6e 77 69 6e 64 |form))..|.(unwind|
|00005230| 2d 70 72 6f 74 65 63 74 | 20 09 09 28 63 6f 6d 70 |-protect| ..(comp|
|00005240| 69 6c 65 2d 75 6e 77 69 | 6e 64 2d 70 72 6f 74 65 |ile-unwi|nd-prote|
|00005250| 63 74 2d 66 6f 72 6d 20 | 66 6f 72 6d 29 29 0d 09 |ct-form |form))..|
|00005260| 09 28 6d 75 6c 74 69 70 | 6c 65 2d 76 61 6c 75 65 |.(multip|le-value|
|00005270| 2d 63 61 6c 6c 20 09 28 | 63 6f 6d 70 69 6c 65 2d |-call .(|compile-|
|00005280| 6d 75 6c 74 69 70 6c 65 | 2d 76 61 6c 75 65 2d 63 |multiple|-value-c|
|00005290| 61 6c 6c 2d 66 6f 72 6d | 20 66 6f 72 6d 29 29 0d |all-form| form)).|
|000052a0| 09 09 28 65 76 61 6c 2d | 77 68 65 6e 20 09 09 09 |..(eval-|when ...|
|000052b0| 09 28 63 6f 6d 70 69 6c | 65 2d 65 76 61 6c 2d 77 |.(compil|e-eval-w|
|000052c0| 68 65 6e 2d 66 6f 72 6d | 20 66 6f 72 6d 29 29 0d |hen-form| form)).|
|000052d0| 09 09 28 64 65 63 6c 61 | 72 65 09 09 09 09 6e 69 |..(decla|re....ni|
|000052e0| 6c 29 0d 09 09 28 6f 74 | 68 65 72 77 69 73 65 20 |l)...(ot|herwise |
|000052f0| 09 09 09 09 28 65 72 72 | 6f 72 20 22 53 70 65 63 |....(err|or "Spec|
|00005300| 69 61 6c 20 66 6f 72 6d | 20 6e 6f 74 20 73 75 70 |ial form| not sup|
|00005310| 70 6f 72 74 65 64 3a 20 | 7e 41 7e 25 22 20 28 63 |ported: |~A~%" (c|
|00005320| 61 72 20 66 6f 72 6d 29 | 29 29 29 29 0d 0d 0d 28 |ar form)|))))...(|
|00005330| 64 65 66 75 6e 20 63 6f | 6d 70 69 6c 65 2d 65 78 |defun co|mpile-ex|
|00005340| 70 6c 69 63 69 74 2d 6c | 61 6d 62 64 61 20 28 66 |plicit-l|ambda (f|
|00005350| 6f 72 6d 29 0d 09 28 69 | 66 20 28 6e 6f 74 20 28 |orm)..(i|f (not (|
|00005360| 65 71 20 27 6c 61 6d 62 | 64 61 20 28 63 61 61 72 |eq 'lamb|da (caar|
|00005370| 20 66 6f 72 6d 29 29 29 | 0d 09 09 28 65 72 72 6f | form)))|...(erro|
|00005380| 72 20 22 54 68 65 20 66 | 69 72 73 74 20 65 6c 65 |r "The f|irst ele|
|00005390| 6d 65 6e 74 20 6f 66 20 | 74 68 65 20 65 78 70 72 |ment of |the expr|
|000053a0| 65 73 73 69 6f 6e 3a 20 | 7e 41 20 69 73 20 61 20 |ession: |~A is a |
|000053b0| 6c 69 73 74 20 62 75 74 | 20 69 74 0d 09 09 09 09 |list but| it.....|
|000053c0| 69 73 6e 27 74 20 61 20 | 6c 61 6d 62 64 61 20 65 |isn't a |lambda e|
|000053d0| 78 70 72 65 73 73 69 6f | 6e 7e 25 22 20 28 63 61 |xpressio|n~%" (ca|
|000053e0| 72 20 66 6f 72 6d 29 29 | 29 0d 09 28 63 6f 6d 70 |r form))|)..(comp|
|000053f0| 69 6c 65 2d 66 6f 72 6d | 20 60 28 66 75 6e 63 61 |ile-form| `(funca|
|00005400| 6c 6c 20 28 66 75 6e 63 | 74 69 6f 6e 20 2c 28 63 |ll (func|tion ,(c|
|00005410| 61 72 20 66 6f 72 6d 29 | 29 20 2c 40 28 63 64 72 |ar form)|) ,@(cdr|
|00005420| 20 66 6f 72 6d 29 29 29 | 29 0d 0d 28 64 65 66 75 | form)))|)..(defu|
|00005430| 6e 20 63 6f 6d 70 69 6c | 65 2d 73 79 6d 62 6f 6c |n compil|e-symbol|
|00005440| 20 28 73 79 6d 29 0d 09 | 28 6c 65 74 20 28 28 74 | (sym)..|(let ((t|
|00005450| 65 6d 70 20 28 66 69 6e | 64 2d 6c 65 78 20 73 79 |emp (fin|d-lex sy|
|00005460| 6d 29 29 29 09 09 3b 20 | 63 68 65 63 6b 20 66 6f |m)))..; |check fo|
|00005470| 72 20 6c 65 78 69 63 61 | 6c 20 76 61 72 69 61 62 |r lexica|l variab|
|00005480| 6c 65 0d 09 09 28 69 66 | 20 74 65 6d 70 0d 09 09 |le...(if| temp...|
|00005490| 09 28 69 66 20 28 69 6e | 74 65 67 65 72 70 20 28 |.(if (in|tegerp (|
|000054a0| 63 64 72 20 74 65 6d 70 | 29 29 0d 09 09 09 09 5b |cdr temp|)).....[|
|000054b0| 0d 09 09 09 09 09 60 28 | 6d 6f 76 65 2e 6c 20 28 |......`(|move.l (|
|000054c0| 61 33 20 2c 28 2a 20 28 | 63 64 72 20 74 65 6d 70 |a3 ,(* (|cdr temp|
|000054d0| 29 20 34 29 29 20 64 33 | 29 0d 09 09 09 09 5d 0d |) 4)) d3|).....].|
|000054e0| 09 09 09 09 3b 3b 20 65 | 6c 73 65 0d 09 09 09 09 |....;; e|lse.....|
|000054f0| 5b 0d 09 09 09 09 09 60 | 28 6d 6f 76 65 2e 6c 20 |[......`|(move.l |
|00005500| 28 61 33 20 2c 28 2a 20 | 28 63 61 64 72 20 74 65 |(a3 ,(* |(cadr te|
|00005510| 6d 70 29 20 34 29 29 20 | 61 30 29 0d 09 09 09 09 |mp) 4)) |a0).....|
|00005520| 09 60 28 24 43 44 52 20 | 61 30 20 64 33 29 0d 09 |.`($CDR |a0 d3)..|
|00005530| 09 09 09 5d 29 0d 09 09 | 3b 3b 20 65 6c 73 65 20 |...])...|;; else |
|00005540| 73 65 65 20 69 66 20 69 | 74 20 69 73 20 69 6e 20 |see if i|t is in |
|00005550| 74 68 65 20 69 6e 68 65 | 72 69 74 65 64 20 65 6e |the inhe|rited en|
|00005560| 76 69 72 6f 6e 6d 65 6e | 74 0d 09 09 09 28 69 66 |vironmen|t....(if|
|00005570| 20 28 6d 65 6d 62 65 72 | 20 73 79 6d 20 2a 65 6e | (member| sym *en|
|00005580| 76 69 72 6f 6e 6d 65 6e | 74 2a 29 0d 09 09 09 09 |vironmen|t*).....|
|00005590| 5b 0d 09 09 09 09 09 60 | 28 6d 6f 76 65 2e 6c 20 |[......`|(move.l |
|000055a0| 30 20 28 2d 61 37 29 29 | 0d 09 09 09 09 09 60 28 |0 (-a7))|......`(|
|000055b0| 6d 6f 76 65 2e 6c 20 27 | 2c 73 79 6d 20 28 2d 61 |move.l '|,sym (-a|
|000055c0| 37 29 29 0d 09 09 09 09 | 09 60 28 6d 6f 76 65 2e |7)).....|.`(move.|
|000055d0| 6c 20 61 34 20 28 2d 61 | 37 29 29 0d 09 09 09 09 |l a4 (-a|7)).....|
|000055e0| 09 60 28 6d 6f 76 65 2e | 6c 20 61 37 20 28 2d 61 |.`(move.|l a7 (-a|
|000055f0| 37 29 29 0d 09 09 09 09 | 09 60 28 6a 73 72 20 23 |7)).....|.`(jsr #|
|00005600| 27 25 65 6e 76 69 72 6f | 6e 6d 65 6e 74 2d 67 65 |'%enviro|nment-ge|
|00005610| 74 2d 76 61 6c 75 65 29 | 0d 09 09 09 09 09 60 28 |t-value)|......`(|
|00005620| 6c 65 61 20 28 61 37 20 | 31 36 29 20 61 37 29 0d |lea (a7 |16) a7).|
|00005630| 09 09 09 09 09 60 28 6d | 6f 76 65 2e 6c 20 64 30 |.....`(m|ove.l d0|
|00005640| 20 64 33 29 0d 09 09 09 | 09 5d 0d 09 09 09 3b 3b | d3)....|.]....;;|
|00005650| 20 65 6c 73 65 20 61 73 | 73 75 6d 65 20 73 70 65 | else as|sume spe|
|00005660| 63 69 61 6c 20 76 61 72 | 69 61 62 6c 65 0d 09 09 |cial var|iable...|
|00005670| 09 09 28 63 6f 6d 70 69 | 6c 65 2d 66 75 6e 63 74 |..(compi|le-funct|
|00005680| 69 6f 6e 2d 63 61 6c 6c | 2d 66 6f 72 6d 20 60 28 |ion-call|-form `(|
|00005690| 73 79 6d 62 6f 6c 2d 76 | 61 6c 75 65 20 27 2c 73 |symbol-v|alue ',s|
|000056a0| 79 6d 29 29 29 29 29 29 | 0d 09 09 09 09 0d 0d 28 |ym))))))|.......(|
|000056b0| 64 65 66 75 6e 20 63 6f | 6d 70 69 6c 65 2d 69 66 |defun co|mpile-if|
|000056c0| 2d 66 6f 72 6d 20 28 66 | 6f 72 6d 29 0d 09 28 6c |-form (f|orm)..(l|
|000056d0| 65 74 20 28 28 65 6c 73 | 65 2d 6c 61 62 65 6c 20 |et ((els|e-label |
|000056e0| 28 67 65 6e 73 79 6d 29 | 29 20 0d 09 09 20 20 28 |(gensym)|) ... (|
|000056f0| 65 6e 64 2d 6c 61 62 65 | 6c 20 28 67 65 6e 73 79 |end-labe|l (gensy|
|00005700| 6d 29 29 0d 09 09 20 20 | 28 74 65 73 74 2d 66 6f |m))... |(test-fo|
|00005710| 72 6d 20 28 63 61 64 72 | 20 66 6f 72 6d 29 29 0d |rm (cadr| form)).|
|00005720| 09 09 20 20 28 74 68 65 | 6e 2d 66 6f 72 6d 20 28 |.. (the|n-form (|
|00005730| 63 61 64 64 72 20 66 6f | 72 6d 29 29 0d 09 09 20 |caddr fo|rm))... |
|00005740| 20 28 65 6c 73 65 2d 66 | 6f 72 6d 20 28 63 64 64 | (else-f|orm (cdd|
|00005750| 64 72 20 66 6f 72 6d 29 | 29 29 0d 0d 09 09 28 63 |dr form)|))....(c|
|00005760| 6f 6d 70 69 6c 65 2d 66 | 6f 72 6d 20 74 65 73 74 |ompile-f|orm test|
|00005770| 2d 66 6f 72 6d 29 0d 09 | 09 5b 0d 09 09 09 60 28 |-form)..|.[....`(|
|00005780| 63 6d 70 2e 6c 20 27 6e | 69 6c 20 64 33 29 0d 09 |cmp.l 'n|il d3)..|
|00005790| 09 09 60 28 62 65 71 20 | 2c 65 6c 73 65 2d 6c 61 |..`(beq |,else-la|
|000057a0| 62 65 6c 29 0d 09 09 5d | 0d 09 09 28 63 6f 6d 70 |bel)...]|...(comp|
|000057b0| 69 6c 65 2d 66 6f 72 6d | 20 74 68 65 6e 2d 66 6f |ile-form| then-fo|
|000057c0| 72 6d 29 0d 09 09 28 69 | 66 20 28 63 6f 6e 73 70 |rm)...(i|f (consp|
|000057d0| 20 65 6c 73 65 2d 66 6f | 72 6d 29 0d 09 09 09 5b | else-fo|rm)....[|
|000057e0| 0d 09 09 09 09 60 28 62 | 72 61 20 2c 65 6e 64 2d |.....`(b|ra ,end-|
|000057f0| 6c 61 62 65 6c 29 0d 09 | 09 09 5d 29 0d 09 09 5b |label)..|..])...[|
|00005800| 0d 09 09 09 65 6c 73 65 | 2d 6c 61 62 65 6c 0d 09 |....else|-label..|
|00005810| 09 5d 0d 09 09 28 69 66 | 20 28 63 6f 6e 73 70 20 |.]...(if| (consp |
|00005820| 65 6c 73 65 2d 66 6f 72 | 6d 29 0d 09 09 09 28 63 |else-for|m)....(c|
|00005830| 6f 6d 70 69 6c 65 2d 66 | 6f 72 6d 20 28 63 61 72 |ompile-f|orm (car|
|00005840| 20 65 6c 73 65 2d 66 6f | 72 6d 29 29 29 0d 09 09 | else-fo|rm)))...|
|00005850| 5b 0d 09 09 09 65 6e 64 | 2d 6c 61 62 65 6c 0d 09 |[....end|-label..|
|00005860| 09 5d 29 29 0d 0d 0d 28 | 64 65 66 75 6e 20 63 6f |.]))...(|defun co|
|00005870| 6d 70 69 6c 65 2d 74 61 | 67 62 6f 64 79 2d 66 6f |mpile-ta|gbody-fo|
|00005880| 72 6d 20 28 66 6f 72 6d | 29 0d 09 28 6c 65 74 20 |rm (form|)..(let |
|00005890| 28 28 74 61 67 73 20 6e | 69 6c 29 29 0d 09 09 3b |((tags n|il))...;|
|000058a0| 3b 20 67 6f 20 74 68 72 | 6f 75 67 68 20 6c 69 73 |; go thr|ough lis|
|000058b0| 74 20 6f 6e 63 65 20 63 | 6f 6c 6c 65 63 74 69 6e |t once c|ollectin|
|000058c0| 67 20 74 61 67 73 0d 09 | 09 28 64 6f 6c 69 73 74 |g tags..|.(dolist|
|000058d0| 20 28 6e 20 28 63 64 72 | 20 66 6f 72 6d 29 29 0d | (n (cdr| form)).|
|000058e0| 09 09 09 28 69 66 20 28 | 6f 72 20 28 69 6e 74 65 |...(if (|or (inte|
|000058f0| 67 65 72 70 20 6e 29 20 | 28 73 79 6d 62 6f 6c 70 |gerp n) |(symbolp|
|00005900| 20 6e 29 29 0d 09 09 09 | 09 28 70 75 73 68 20 28 | n))....|.(push (|
|00005910| 63 6f 6e 73 20 6e 20 28 | 67 65 6e 73 79 6d 29 29 |cons n (|gensym))|
|00005920| 20 74 61 67 73 29 29 29 | 0d 09 09 0d 09 09 28 70 | tags)))|......(p|
|00005930| 75 73 68 2d 63 6c 65 61 | 6e 75 70 20 28 63 6f 6e |ush-clea|nup (con|
|00005940| 73 20 27 74 61 67 62 6f | 64 79 20 74 61 67 73 29 |s 'tagbo|dy tags)|
|00005950| 29 0d 0d 09 09 28 64 6f | 6c 69 73 74 20 28 6e 20 |)....(do|list (n |
|00005960| 28 63 64 72 20 66 6f 72 | 6d 29 29 0d 09 09 09 28 |(cdr for|m))....(|
|00005970| 69 66 20 28 6f 72 20 28 | 69 6e 74 65 67 65 72 70 |if (or (|integerp|
|00005980| 20 6e 29 20 28 73 79 6d | 62 6f 6c 70 20 6e 29 29 | n) (sym|bolp n))|
|00005990| 0d 09 09 09 09 28 70 75 | 73 68 20 28 63 64 72 20 |.....(pu|sh (cdr |
|000059a0| 28 61 73 73 6f 63 20 6e | 20 74 61 67 73 29 29 20 |(assoc n| tags)) |
|000059b0| 2a 61 73 6d 2a 29 0d 09 | 09 09 09 3b 3b 20 65 6c |*asm*)..|...;; el|
|000059c0| 73 65 20 69 74 20 69 73 | 20 61 20 66 6f 72 6d 20 |se it is| a form |
|000059d0| 74 6f 20 62 65 20 65 76 | 61 6c 75 61 74 65 64 0d |to be ev|aluated.|
|000059e0| 09 09 09 09 28 63 6f 6d | 70 69 6c 65 2d 66 6f 72 |....(com|pile-for|
|000059f0| 6d 20 6e 29 29 29 0d 0d | 09 09 28 70 6f 70 2d 63 |m n)))..|..(pop-c|
|00005a00| 6c 65 61 6e 75 70 29 29 | 29 0d 09 09 09 0d 28 64 |leanup))|).....(d|
|00005a10| 65 66 75 6e 20 63 6f 6d | 70 69 6c 65 2d 67 6f 2d |efun com|pile-go-|
|00005a20| 74 61 67 20 28 66 6f 72 | 6d 29 0d 09 28 6c 65 74 |tag (for|m)..(let|
|00005a30| 20 28 28 74 61 67 20 28 | 63 61 64 72 20 66 6f 72 | ((tag (|cadr for|
|00005a40| 6d 29 29 29 0d 09 09 28 | 69 66 20 28 6e 6f 74 20 |m)))...(|if (not |
|00005a50| 28 6f 72 20 28 69 6e 74 | 65 67 65 72 70 20 74 61 |(or (int|egerp ta|
|00005a60| 67 29 20 28 73 79 6d 62 | 6f 6c 70 20 74 61 67 29 |g) (symb|olp tag)|
|00005a70| 29 29 0d 09 09 09 28 65 | 72 72 6f 72 20 22 49 6e |))....(e|rror "In|
|00005a80| 76 61 6c 69 64 20 67 6f | 20 74 61 67 20 65 6e 63 |valid go| tag enc|
|00005a90| 6f 75 6e 74 65 72 65 64 | 22 29 29 0d 09 09 28 69 |ountered|"))...(i|
|00005aa0| 66 20 28 6e 6f 74 20 28 | 66 69 6e 64 2d 67 6f 2d |f (not (|find-go-|
|00005ab0| 74 61 67 20 74 61 67 29 | 29 09 09 09 3b 3b 20 69 |tag tag)|)...;; i|
|00005ac0| 66 20 74 68 65 20 74 61 | 67 20 69 73 20 6e 6f 74 |f the ta|g is not|
|00005ad0| 20 61 6c 72 65 61 64 79 | 20 64 65 66 69 6e 65 64 | already| defined|
|00005ae0| 20 0d 09 09 09 28 65 72 | 72 6f 72 20 22 54 61 67 | ....(er|ror "Tag|
|00005af0| 20 6e 6f 74 20 64 65 66 | 69 6e 65 64 20 69 6e 20 | not def|ined in |
|00005b00| 74 68 69 73 20 73 63 6f | 70 65 22 29 29 0d 0d 09 |this sco|pe"))...|
|00005b10| 09 3b 3b 20 70 65 65 6c | 20 6f 66 66 20 63 6c 65 |.;; peel| off cle|
|00005b20| 61 6e 75 70 20 73 74 61 | 63 6b 0d 09 09 28 6c 65 |anup sta|ck...(le|
|00005b30| 74 20 28 28 64 65 73 74 | 20 28 66 69 6e 64 2d 67 |t ((dest| (find-g|
|00005b40| 6f 2d 74 61 67 2d 74 61 | 67 62 6f 64 79 20 74 61 |o-tag-ta|gbody ta|
|00005b50| 67 29 29 29 0d 09 09 09 | 28 64 6f 6c 69 73 74 20 |g)))....|(dolist |
|00005b60| 28 66 20 2a 63 6c 65 61 | 6e 75 70 2d 66 6f 72 6d |(f *clea|nup-form|
|00005b70| 73 2d 73 74 61 63 6b 2a | 29 0d 09 09 09 09 28 69 |s-stack*|).....(i|
|00005b80| 66 20 28 65 71 20 66 20 | 64 65 73 74 29 20 28 72 |f (eq f |dest) (r|
|00005b90| 65 74 75 72 6e 29 29 09 | 09 3b 3b 20 72 65 74 75 |eturn)).|.;; retu|
|00005ba0| 72 6e 73 20 66 72 6f 6d | 20 74 68 65 20 64 6f 6c |rns from| the dol|
|00005bb0| 69 73 74 20 62 6c 6f 63 | 6b 0d 09 09 09 09 28 63 |ist bloc|k.....(c|
|00005bc0| 61 73 65 20 28 63 61 72 | 20 66 29 0d 09 09 09 09 |ase (car| f).....|
|00005bd0| 09 28 75 6e 77 69 6e 64 | 2d 70 72 6f 74 65 63 74 |.(unwind|-protect|
|00005be0| 20 20 0d 09 09 09 09 09 | 09 3b 3b 20 69 6e 63 6c | ......|.;; incl|
|00005bf0| 75 64 65 20 63 6c 65 61 | 6e 75 70 20 63 6f 64 65 |ude clea|nup code|
|00005c00| 0d 09 09 09 09 09 09 28 | 6c 65 74 20 28 28 63 6c |.......(|let ((cl|
|00005c10| 65 61 6e 75 70 2d 63 6f | 64 65 20 28 63 64 72 20 |eanup-co|de (cdr |
|00005c20| 66 29 29 29 0d 09 09 09 | 09 09 09 09 28 64 6f 6c |f)))....|....(dol|
|00005c30| 69 73 74 20 28 6e 20 63 | 6c 65 61 6e 75 70 2d 63 |ist (n c|leanup-c|
|00005c40| 6f 64 65 29 0d 09 09 09 | 09 09 09 09 09 28 70 75 |ode)....|.....(pu|
|00005c50| 73 68 20 6e 20 2a 61 73 | 6d 2a 29 29 29 29 0d 09 |sh n *as|m*))))..|
|00005c60| 09 09 09 09 28 63 61 74 | 63 68 0d 09 09 09 09 09 |....(cat|ch......|
|00005c70| 09 3b 3b 20 72 65 6d 6f | 76 65 20 64 79 6e 61 6d |.;; remo|ve dynam|
|00005c80| 69 63 20 63 61 74 63 68 | 20 74 61 67 0d 09 09 09 |ic catch| tag....|
|00005c90| 09 09 09 5b 0d 09 09 09 | 09 09 09 09 60 28 6a 73 |...[....|....`(js|
|00005ca0| 72 20 23 27 63 6f 6d 6d | 6f 6e 2d 6c 69 73 70 3a |r #'comm|on-lisp:|
|00005cb0| 3a 25 70 6f 70 43 61 74 | 63 68 65 72 29 09 3b 3b |:%popCat|cher).;;|
|00005cc0| 20 72 65 73 74 6f 72 65 | 20 72 65 73 75 6c 74 0d | restore| result.|
|00005cd0| 09 09 09 09 09 09 5d 29 | 29 29 29 0d 09 09 09 09 |......])|))).....|
|00005ce0| 09 0d 09 09 5b 0d 09 09 | 09 60 28 62 72 61 20 2c |....[...|.`(bra ,|
|00005cf0| 28 63 64 72 20 28 66 69 | 6e 64 2d 67 6f 2d 74 61 |(cdr (fi|nd-go-ta|
|00005d00| 67 20 74 61 67 29 29 29 | 0d 09 09 5d 29 29 20 0d |g tag)))|...])) .|
|00005d10| 0d 28 64 65 66 75 6e 20 | 63 6f 6d 70 69 6c 65 2d |.(defun |compile-|
|00005d20| 73 65 74 71 2d 66 6f 72 | 6d 20 28 66 6f 72 6d 29 |setq-for|m (form)|
|00005d30| 0d 09 28 64 6f 20 28 28 | 66 20 28 63 64 72 20 66 |..(do ((|f (cdr f|
|00005d40| 6f 72 6d 29 20 28 63 64 | 64 72 20 66 29 29 20 76 |orm) (cd|dr f)) v|
|00005d50| 61 72 20 76 61 6c 20 74 | 65 6d 70 29 0d 09 09 28 |ar val t|emp)...(|
|00005d60| 28 65 6e 64 70 20 66 29 | 29 0d 09 09 28 73 65 74 |(endp f)|)...(set|
|00005d70| 71 20 76 61 72 20 28 63 | 61 72 20 66 29 29 0d 09 |q var (c|ar f))..|
|00005d80| 09 28 73 65 74 71 20 76 | 61 6c 20 28 63 61 64 72 |.(setq v|al (cadr|
|00005d90| 20 66 29 29 0d 09 09 28 | 73 65 74 66 20 74 65 6d | f))...(|setf tem|
|00005da0| 70 20 28 66 69 6e 64 2d | 6c 65 78 20 76 61 72 29 |p (find-|lex var)|
|00005db0| 29 09 3b 20 63 68 65 63 | 6b 20 66 6f 72 20 6c 65 |).; chec|k for le|
|00005dc0| 78 69 63 61 6c 20 76 61 | 72 69 61 62 6c 65 0d 09 |xical va|riable..|
|00005dd0| 09 28 69 66 20 74 65 6d | 70 0d 09 09 09 28 70 72 |.(if tem|p....(pr|
|00005de0| 6f 67 6e 0d 09 09 09 09 | 28 63 6f 6d 70 69 6c 65 |ogn.....|(compile|
|00005df0| 2d 66 6f 72 6d 20 76 61 | 6c 29 0d 09 09 09 09 28 |-form va|l).....(|
|00005e00| 69 66 20 28 69 6e 74 65 | 67 65 72 70 20 28 63 64 |if (inte|gerp (cd|
|00005e10| 72 20 74 65 6d 70 29 29 | 0d 09 09 09 09 09 5b 0d |r temp))|......[.|
|00005e20| 09 09 09 09 09 09 60 28 | 6d 6f 76 65 2e 6c 20 64 |......`(|move.l d|
|00005e30| 33 20 28 61 33 20 2c 28 | 2a 20 28 63 64 72 20 74 |3 (a3 ,(|* (cdr t|
|00005e40| 65 6d 70 29 20 34 29 29 | 29 0d 09 09 09 09 09 5d |emp) 4))|)......]|
|00005e50| 0d 09 09 09 09 3b 3b 20 | 65 6c 73 65 0d 09 09 09 |.....;; |else....|
|00005e60| 09 09 5b 0d 09 09 09 09 | 09 09 60 28 6d 6f 76 65 |..[.....|..`(move|
|00005e70| 2e 6c 20 28 61 33 20 2c | 28 2a 20 28 63 61 64 72 |.l (a3 ,|(* (cadr|
|00005e80| 20 74 65 6d 70 29 20 34 | 29 29 20 61 30 29 0d 09 | temp) 4|)) a0)..|
|00005e90| 09 09 09 09 09 60 28 24 | 53 45 54 43 44 52 20 61 |.....`($|SETCDR a|
|00005ea0| 30 20 64 33 29 0d 09 09 | 09 09 09 5d 29 29 0d 09 |0 d3)...|...]))..|
|00005eb0| 09 3b 3b 20 65 6c 73 65 | 20 6c 6f 6f 6b 20 69 6e |.;; else| look in|
|00005ec0| 20 74 68 65 20 69 6e 68 | 65 72 69 74 65 64 20 65 | the inh|erited e|
|00005ed0| 6e 76 69 72 6f 6e 6d 65 | 6e 74 0d 09 09 09 28 69 |nvironme|nt....(i|
|00005ee0| 66 20 28 6d 65 6d 62 65 | 72 20 76 61 72 20 2a 65 |f (membe|r var *e|
|00005ef0| 6e 76 69 72 6f 6e 6d 65 | 6e 74 2a 29 0d 09 09 09 |nvironme|nt*)....|
|00005f00| 09 28 70 72 6f 67 6e 0d | 09 09 09 09 09 28 63 6f |.(progn.|.....(co|
|00005f10| 6d 70 69 6c 65 2d 66 6f | 72 6d 20 76 61 6c 29 0d |mpile-fo|rm val).|
|00005f20| 09 09 09 09 09 5b 0d 09 | 09 09 09 09 09 60 28 6d |.....[..|.....`(m|
|00005f30| 6f 76 65 2e 6c 20 30 20 | 28 2d 61 37 29 29 0d 09 |ove.l 0 |(-a7))..|
|00005f40| 09 09 09 09 09 60 28 6d | 6f 76 65 2e 6c 20 64 33 |.....`(m|ove.l d3|
|00005f50| 20 28 2d 61 37 29 29 0d | 09 09 09 09 09 09 60 28 | (-a7)).|......`(|
|00005f60| 6d 6f 76 65 2e 6c 20 27 | 2c 76 61 72 20 28 2d 61 |move.l '|,var (-a|
|00005f70| 37 29 29 0d 09 09 09 09 | 09 09 60 28 6d 6f 76 65 |7)).....|..`(move|
|00005f80| 2e 6c 20 61 34 20 28 2d | 61 37 29 29 0d 09 09 09 |.l a4 (-|a7))....|
|00005f90| 09 09 09 60 28 6d 6f 76 | 65 2e 6c 20 61 37 20 28 |...`(mov|e.l a7 (|
|00005fa0| 2d 61 37 29 29 0d 09 09 | 09 09 09 09 60 28 6a 73 |-a7))...|....`(js|
|00005fb0| 72 20 23 27 25 65 6e 76 | 69 72 6f 6e 6d 65 6e 74 |r #'%env|ironment|
|00005fc0| 2d 73 65 74 2d 76 61 6c | 75 65 29 0d 09 09 09 09 |-set-val|ue).....|
|00005fd0| 09 09 60 28 6c 65 61 20 | 28 61 37 20 32 30 29 20 |..`(lea |(a7 20) |
|00005fe0| 61 37 29 0d 09 09 09 09 | 09 09 60 28 6d 6f 76 65 |a7).....|..`(move|
|00005ff0| 2e 6c 20 64 30 20 64 33 | 29 0d 09 09 09 09 09 5d |.l d0 d3|)......]|
|00006000| 29 0d 09 09 09 3b 3b 20 | 65 6c 73 65 20 63 61 6c |)....;; |else cal|
|00006010| 6c 20 73 65 74 20 66 75 | 6e 63 74 69 6f 6e 0d 09 |l set fu|nction..|
|00006020| 09 09 09 28 63 6f 6d 70 | 69 6c 65 2d 66 6f 72 6d |...(comp|ile-form|
|00006030| 20 60 28 73 65 74 20 27 | 2c 76 61 72 20 2c 76 61 | `(set '|,var ,va|
|00006040| 6c 29 29 29 29 29 29 0d | 0d 0d 28 64 65 66 75 6e |l)))))).|..(defun|
|00006050| 20 63 6f 6d 70 69 6c 65 | 2d 71 75 6f 74 65 2d 66 | compile|-quote-f|
|00006060| 6f 72 6d 20 28 66 6f 72 | 6d 29 0d 09 28 63 6f 6d |orm (for|m)..(com|
|00006070| 70 69 6c 65 2d 6c 69 74 | 65 72 61 6c 2d 66 6f 72 |pile-lit|eral-for|
|00006080| 6d 20 28 63 61 64 72 20 | 66 6f 72 6d 29 29 29 0d |m (cadr |form))).|
|00006090| 0d 28 64 65 66 75 6e 20 | 63 6f 6d 70 69 6c 65 2d |.(defun |compile-|
|000060a0| 62 6c 6f 63 6b 2d 66 6f | 72 6d 20 28 66 6f 72 6d |block-fo|rm (form|
|000060b0| 29 0d 09 28 6c 65 74 20 | 28 28 62 6c 6f 63 6b 2d |)..(let |((block-|
|000060c0| 6e 61 6d 65 20 28 63 61 | 64 72 20 66 6f 72 6d 29 |name (ca|dr form)|
|000060d0| 29 20 0d 09 09 20 20 28 | 62 6c 6f 63 6b 2d 66 6f |) ... (|block-fo|
|000060e0| 72 6d 73 20 28 63 64 64 | 72 20 66 6f 72 6d 29 29 |rms (cdd|r form))|
|000060f0| 20 0d 09 09 20 20 28 65 | 78 69 74 2d 6c 61 62 65 | ... (e|xit-labe|
|00006100| 6c 20 28 67 65 6e 73 79 | 6d 29 29 29 0d 09 09 28 |l (gensy|m)))...(|
|00006110| 70 75 73 68 2d 63 6c 65 | 61 6e 75 70 20 28 6c 69 |push-cle|anup (li|
|00006120| 73 74 20 27 62 6c 6f 63 | 6b 20 62 6c 6f 63 6b 2d |st 'bloc|k block-|
|00006130| 6e 61 6d 65 20 65 78 69 | 74 2d 6c 61 62 65 6c 29 |name exi|t-label)|
|00006140| 29 0d 0d 09 09 28 64 6f | 6c 69 73 74 20 28 66 20 |)....(do|list (f |
|00006150| 62 6c 6f 63 6b 2d 66 6f | 72 6d 73 29 0d 09 09 09 |block-fo|rms)....|
|00006160| 28 63 6f 6d 70 69 6c 65 | 2d 66 6f 72 6d 20 66 29 |(compile|-form f)|
|00006170| 29 0d 0d 09 09 5b 0d 09 | 09 09 65 78 69 74 2d 6c |)....[..|..exit-l|
|00006180| 61 62 65 6c 0d 09 09 5d | 0d 09 09 28 70 6f 70 2d |abel...]|...(pop-|
|00006190| 63 6c 65 61 6e 75 70 29 | 29 29 0d 0d 28 64 65 66 |cleanup)|))..(def|
|000061a0| 75 6e 20 63 6f 6d 70 69 | 6c 65 2d 72 65 74 75 72 |un compi|le-retur|
|000061b0| 6e 2d 66 72 6f 6d 2d 66 | 6f 72 6d 20 28 66 6f 72 |n-from-f|orm (for|
|000061c0| 6d 29 0d 09 28 6c 65 74 | 20 28 28 62 6c 6f 63 6b |m)..(let| ((block|
|000061d0| 2d 6e 61 6d 65 20 28 63 | 61 64 72 20 66 6f 72 6d |-name (c|adr form|
|000061e0| 29 29 0d 09 09 20 20 28 | 72 65 74 76 61 6c 20 6e |))... (|retval n|
|000061f0| 69 6c 29 0d 09 09 20 20 | 74 65 6d 70 29 0d 09 09 |il)... |temp)...|
|00006200| 28 69 66 20 28 63 6f 6e | 73 70 20 28 63 64 64 72 |(if (con|sp (cddr|
|00006210| 20 66 6f 72 6d 29 29 0d | 09 09 09 28 73 65 74 71 | form)).|...(setq|
|00006220| 20 72 65 74 76 61 6c 20 | 28 63 61 64 64 72 20 66 | retval |(caddr f|
|00006230| 6f 72 6d 29 29 29 0d 09 | 09 28 63 6f 6d 70 69 6c |orm)))..|.(compil|
|00006240| 65 2d 66 6f 72 6d 20 72 | 65 74 76 61 6c 29 0d 09 |e-form r|etval)..|
|00006250| 09 28 69 66 20 28 6e 75 | 6c 6c 20 62 6c 6f 63 6b |.(if (nu|ll block|
|00006260| 2d 6e 61 6d 65 29 0d 09 | 09 09 28 73 65 74 71 20 |-name)..|..(setq |
|00006270| 74 65 6d 70 20 28 66 69 | 6e 64 2d 61 6e 79 2d 62 |temp (fi|nd-any-b|
|00006280| 6c 6f 63 6b 29 29 0d 09 | 09 09 3b 3b 20 65 6c 73 |lock))..|..;; els|
|00006290| 65 0d 09 09 09 28 73 65 | 74 71 20 74 65 6d 70 20 |e....(se|tq temp |
|000062a0| 28 66 69 6e 64 2d 62 6c | 6f 63 6b 20 62 6c 6f 63 |(find-bl|ock bloc|
|000062b0| 6b 2d 6e 61 6d 65 29 29 | 29 0d 09 09 28 75 6e 6c |k-name))|)...(unl|
|000062c0| 65 73 73 20 74 65 6d 70 | 20 28 65 72 72 6f 72 20 |ess temp| (error |
|000062d0| 22 42 6c 6f 63 6b 20 6c | 61 62 65 6c 20 6e 6f 74 |"Block l|abel not|
|000062e0| 20 66 6f 75 6e 64 22 29 | 29 0d 0d 09 09 3b 3b 20 | found")|)....;; |
|000062f0| 70 65 65 6c 20 6f 66 66 | 20 63 6c 65 61 6e 75 70 |peel off| cleanup|
|00006300| 20 73 74 61 63 6b 0d 09 | 09 28 6c 65 74 20 28 28 | stack..|.(let ((|
|00006310| 64 65 73 74 20 74 65 6d | 70 29 29 0d 09 09 09 28 |dest tem|p))....(|
|00006320| 64 6f 6c 69 73 74 20 28 | 66 20 2a 63 6c 65 61 6e |dolist (|f *clean|
|00006330| 75 70 2d 66 6f 72 6d 73 | 2d 73 74 61 63 6b 2a 29 |up-forms|-stack*)|
|00006340| 0d 09 09 09 09 28 69 66 | 20 28 65 71 20 66 20 64 |.....(if| (eq f d|
|00006350| 65 73 74 29 20 28 72 65 | 74 75 72 6e 29 29 09 09 |est) (re|turn))..|
|00006360| 3b 3b 20 72 65 74 75 72 | 6e 73 20 66 72 6f 6d 20 |;; retur|ns from |
|00006370| 74 68 65 20 64 6f 6c 69 | 73 74 20 62 6c 6f 63 6b |the doli|st block|
|00006380| 0d 09 09 09 09 28 63 61 | 73 65 20 28 63 61 72 20 |.....(ca|se (car |
|00006390| 66 29 0d 09 09 09 09 09 | 28 75 6e 77 69 6e 64 2d |f)......|(unwind-|
|000063a0| 70 72 6f 74 65 63 74 20 | 20 0d 09 09 09 09 09 09 |protect | .......|
|000063b0| 3b 3b 20 69 6e 63 6c 75 | 64 65 20 63 6c 65 61 6e |;; inclu|de clean|
|000063c0| 75 70 20 63 6f 64 65 0d | 09 09 09 09 09 09 28 6c |up code.|......(l|
|000063d0| 65 74 20 28 28 63 6c 65 | 61 6e 75 70 2d 63 6f 64 |et ((cle|anup-cod|
|000063e0| 65 20 28 63 64 72 20 66 | 29 29 29 0d 09 09 09 09 |e (cdr f|))).....|
|000063f0| 09 09 09 28 64 6f 6c 69 | 73 74 20 28 6e 20 63 6c |...(doli|st (n cl|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.